summaryrefslogtreecommitdiffstats
path: root/tests/layout.c
diff options
context:
space:
mode:
authorAnastasia Klimchuk <aklm@chromium.org>2021-07-20 14:21:46 +1000
committerEdward O'Callaghan <quasisec@chromium.org>2021-07-22 02:03:52 +0000
commite2c8ecf6e07ceb64871798d01a47ec588b527040 (patch)
treeed4fbc3bd764f92c901e30f7006fb317c2c43447 /tests/layout.c
parent242c9bc3ecfdc6992c1e54db9da402a29bf7aba7 (diff)
downloadflashrom-e2c8ecf6e07ceb64871798d01a47ec588b527040.tar.gz
flashrom-e2c8ecf6e07ceb64871798d01a47ec588b527040.tar.bz2
flashrom-e2c8ecf6e07ceb64871798d01a47ec588b527040.zip
tests: Add unit tests for layout sanity checks
Three more tests in this patch where layout does / does not pass sanity checks. BUG=b:193584590 TEST=ninja test Change-Id: Ia21585d60443b2741f3868d7887476090e35f79b Signed-off-by: Anastasia Klimchuk <aklm@chromium.org> Reviewed-on: https://review.coreboot.org/c/flashrom/+/56440 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Edward O'Callaghan <quasisec@chromium.org> Reviewed-by: Nico Huber <nico.h@gmx.de>
Diffstat (limited to 'tests/layout.c')
-rw-r--r--tests/layout.c105
1 files changed, 105 insertions, 0 deletions
diff --git a/tests/layout.c b/tests/layout.c
index 5f0aee56d..59e409bb7 100644
--- a/tests/layout.c
+++ b/tests/layout.c
@@ -16,6 +16,7 @@
#include <include/test.h>
#include <stdio.h>
+#include "flash.h"
#include "layout.h"
#include "libflashrom.h"
@@ -101,3 +102,107 @@ void region_not_included_overlap_test_success(void **state)
flashrom_layout_release(layout);
printf("done\n");
}
+
+void layout_pass_sanity_checks_test_success(void **state)
+{
+ (void) state; /* unused */
+
+ unsigned int region_start = 0x00021000;
+ unsigned int region_end = 0x00031000;
+ unsigned int start = 0;
+ unsigned int len = 0;
+
+ struct flashrom_layout *layout;
+
+ printf("Creating layout with one included region... ");
+ assert_int_equal(0, flashrom_layout_new(&layout));
+ assert_int_equal(0, flashrom_layout_add_region(layout, region_start, region_end, "region"));
+ assert_int_equal(0, flashrom_layout_include_region(layout, "region"));
+ printf("done\n");
+
+ printf("Asserting region range... ");
+ get_region_range(layout, "region", &start, &len);
+ assert_int_equal(start, region_start);
+ assert_int_equal(len, region_end - region_start + 1);
+ printf("done\n");
+
+ printf("Layout passes sanity checks... ");
+
+ struct flashchip chip = {
+ .total_size = 1024,
+ };
+ struct flashrom_flashctx flash = {
+ .chip = &chip,
+ };
+ flashrom_layout_set(&flash, layout);
+ assert_int_equal(0, layout_sanity_checks(&flash));
+
+ printf("done\n");
+
+ printf("Releasing layout... ");
+ flashrom_layout_release(layout);
+ printf("done\n");
+}
+
+void layout_region_invalid_address_test_success(void **state)
+{
+ (void) state; /* unused */
+
+ struct flashrom_layout *layout;
+
+ printf("Creating layout with one included region... ");
+ assert_int_equal(0, flashrom_layout_new(&layout));
+ assert_int_equal(0, flashrom_layout_add_region(layout, 0x60000000, 0x70000000, "region"));
+ assert_int_equal(0, flashrom_layout_include_region(layout, "region"));
+ printf("done\n");
+
+ printf("Layout does not pass sanity checks... ");
+
+ struct flashchip chip = {
+ /* Make sure layout region addresses exceed total size on chip. */
+ .total_size = 1,
+ };
+ struct flashrom_flashctx flash = {
+ .chip = &chip,
+ };
+ flashrom_layout_set(&flash, layout);
+ assert_int_equal(1, layout_sanity_checks(&flash));
+
+ printf("done\n");
+
+ printf("Releasing layout... ");
+ flashrom_layout_release(layout);
+ printf("done\n");
+}
+
+void layout_region_invalid_range_test_success(void **state)
+{
+ (void) state; /* unused */
+
+ struct flashrom_layout *layout;
+
+ printf("Creating layout with one included region... ");
+ assert_int_equal(0, flashrom_layout_new(&layout));
+ /* Make sure address range of region is not positive i.e. start > end. */
+ assert_int_equal(0, flashrom_layout_add_region(layout, 0x00000020, 0x00000010, "region"));
+ assert_int_equal(0, flashrom_layout_include_region(layout, "region"));
+ printf("done\n");
+
+ printf("Layout does not pass sanity checks... ");
+
+ struct flashchip chip = {
+ /* Make sure layout region addresses fit into total size on chip. */
+ .total_size = 1024,
+ };
+ struct flashrom_flashctx flash = {
+ .chip = &chip,
+ };
+ flashrom_layout_set(&flash, layout);
+ assert_int_equal(1, layout_sanity_checks(&flash));
+
+ printf("done\n");
+
+ printf("Releasing layout... ");
+ flashrom_layout_release(layout);
+ printf("done\n");
+}