/* mbed Microcontroller Library * Copyright (c) 2017-2017 ARM Limited * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ #include "mbed.h" #include "unity.h" #include "utest.h" #include "test_env.h" #include "atomic_usage.h" #include "ObservingBlockDevice.h" #include "LittleFileSystem.h" using namespace utest::v1; #define TEST_CYCLES 10 #define TEST_BD_SIZE (16 * 1024) /** * Check that the filesystem is valid after every change * * This test is to ensure that littlefs contains a valid filesystem at * all times. This property is required for handling unexpected power * loss. */ void test_resilience() { HeapBlockDevice bd(TEST_BD_SIZE); // Setup the test setup_atomic_operations(&bd, true); // Run check on every write operation ObservingBlockDevice observer(&bd); observer.attach(check_atomic_operations); // Perform operations printf("Performing %i operations on flash\n", TEST_CYCLES); for (int i = 1; i <= TEST_CYCLES; i++) { int64_t ret = perform_atomic_operations(&observer); TEST_ASSERT_EQUAL(i, ret); } printf("No errors detected\n"); } Case cases[] = { Case("test resilience", test_resilience), }; utest::v1::status_t greentea_test_setup(const size_t number_of_cases) { GREENTEA_SETUP(20, "default_auto"); return greentea_test_setup_handler(number_of_cases); } Specification specification(greentea_test_setup, cases, greentea_test_teardown_handler); int main() { Harness::run(specification); }