Merge branch 'bugfix/nvs_close_nukes_all_handles_v4.2' into 'release/v4.2'
NVS: fixed deinit other partition's handles (v4.2) See merge request espressif/esp-idf!11497
This commit is contained in:
@@ -20,6 +20,8 @@
|
||||
|
||||
using namespace nvs;
|
||||
|
||||
#define TEST_ESP_OK(rc) CHECK((rc) == ESP_OK)
|
||||
|
||||
TEST_CASE("nvs_flash_init_partition_ptr fails due to nullptr arg", "[nvs_custom_part]")
|
||||
{
|
||||
const uint32_t NVS_FLASH_SECTOR = 6;
|
||||
@@ -61,4 +63,45 @@ TEST_CASE("nvs_flash_init_partition_ptr inits one partition", "[nvs_custom_part]
|
||||
CHECK(NVSPartitionManager::get_instance()->deinit_partition("test") == ESP_OK);
|
||||
}
|
||||
|
||||
TEST_CASE("deinit partition doesn't affect other partition's open handles", "[nvs]")
|
||||
{
|
||||
const char *OTHER_PARTITION_NAME = "other_part";
|
||||
const uint32_t NVS_FLASH_SECTOR = 6;
|
||||
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
||||
|
||||
SpiFlashEmulator emu_default(10);
|
||||
emu_default.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
||||
esp_partition_t part_default = {};
|
||||
strcpy(part_default.label, NVS_DEFAULT_PART_NAME);
|
||||
part_default.address = NVS_FLASH_SECTOR * SPI_FLASH_SEC_SIZE;
|
||||
part_default.size = NVS_FLASH_SECTOR_COUNT_MIN * SPI_FLASH_SEC_SIZE;
|
||||
|
||||
SpiFlashEmulator emu_other(10);
|
||||
emu_other.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
||||
esp_partition_t part_other = {};
|
||||
strcpy(part_other.label, OTHER_PARTITION_NAME);
|
||||
part_other.address = NVS_FLASH_SECTOR * SPI_FLASH_SEC_SIZE;
|
||||
part_other.size = NVS_FLASH_SECTOR_COUNT_MIN * SPI_FLASH_SEC_SIZE;
|
||||
|
||||
const char* str = "value 0123456789abcdef0123456789abcdef";
|
||||
const uint8_t blob[8] = {0x0, 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7};
|
||||
|
||||
nvs_handle_t handle_1;
|
||||
|
||||
TEST_ESP_OK(NVSPartitionManager::get_instance()->init_custom(NVS_DEFAULT_PART_NAME,
|
||||
NVS_FLASH_SECTOR,
|
||||
NVS_FLASH_SECTOR_COUNT_MIN));
|
||||
TEST_ESP_OK(NVSPartitionManager::get_instance()->init_custom(OTHER_PARTITION_NAME,
|
||||
NVS_FLASH_SECTOR,
|
||||
NVS_FLASH_SECTOR_COUNT_MIN));
|
||||
|
||||
TEST_ESP_OK(nvs_open_from_partition(OTHER_PARTITION_NAME, "ns", NVS_READWRITE, &handle_1));
|
||||
|
||||
// Deinitializing must not interfere with the open handle from the other partition.
|
||||
TEST_ESP_OK(nvs_flash_deinit_partition(NVS_DEFAULT_PART_NAME));
|
||||
|
||||
TEST_ESP_OK(nvs_set_i32(handle_1, "foo", 0x3456789a));
|
||||
nvs_close(handle_1);
|
||||
|
||||
TEST_ESP_OK(nvs_flash_deinit_partition(OTHER_PARTITION_NAME));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user