2019-11-25 11:32:40 +08:00
|
|
|
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
#include "catch.hpp"
|
|
|
|
#include <algorithm>
|
|
|
|
#include <cstring>
|
|
|
|
#include "nvs_test_api.h"
|
|
|
|
#include "nvs_handle_simple.hpp"
|
|
|
|
#include "nvs_partition_manager.hpp"
|
|
|
|
#include "spi_flash_emulation.h"
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
#include "test_fixtures.hpp"
|
|
|
|
|
2019-11-25 11:32:40 +08:00
|
|
|
#include <iostream>
|
2020-05-12 12:27:31 +08:00
|
|
|
#include <string>
|
2019-11-25 11:32:40 +08:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
using namespace nvs;
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple closes its reference in PartitionManager", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10, "test");
|
2019-11-25 11:32:40 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2019-11-25 11:32:40 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle("test", "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 1);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition("test") == ESP_OK);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple multiple open and closes with PartitionManager", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10, "test");
|
2019-11-25 11:32:40 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2019-11-25 11:32:40 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle1;
|
|
|
|
NVSHandleSimple *handle2;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle("test", "ns_1", NVS_READWRITE, &handle1) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 1);
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle("test", "ns_1", NVS_READWRITE, &handle2) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 2);
|
|
|
|
|
|
|
|
delete handle1;
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 1);
|
|
|
|
|
|
|
|
delete handle2;
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition("test") == ESP_OK);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
TEST_CASE("NVSHandleSimple readonly fails", "[partition_mgr]")
|
2019-11-25 11:32:40 +08:00
|
|
|
{
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2019-11-25 11:32:40 +08:00
|
|
|
|
|
|
|
NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME);
|
|
|
|
NVSHandleSimple *handle_1;
|
|
|
|
NVSHandleSimple *handle_2;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2019-11-25 11:32:40 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
CHECK(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN) == ESP_OK);
|
2019-11-25 11:32:40 +08:00
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
|
|
|
|
// first, creating namespace...
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle_1) == ESP_OK);
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 1);
|
|
|
|
|
|
|
|
delete handle_1;
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READONLY, &handle_2) == ESP_OK);
|
|
|
|
CHECK(handle_2->set_item("key", 47) == ESP_ERR_NVS_READ_ONLY);
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 1);
|
|
|
|
|
|
|
|
delete handle_2;
|
|
|
|
|
|
|
|
CHECK(NVSPartitionManager::get_instance()->open_handles_size() == 0);
|
|
|
|
// without deinit it affects "nvs api tests"
|
|
|
|
CHECK(nvs_flash_deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|
|
|
|
|
2020-05-12 12:27:31 +08:00
|
|
|
TEST_CASE("NVSHandleSimple set/get char", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
enum class TestEnum : char {
|
|
|
|
FOO = -1,
|
|
|
|
BEER,
|
|
|
|
BAR
|
|
|
|
};
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2020-05-12 12:27:31 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
char test_e = 'a';
|
|
|
|
char test_e_read = 'z';
|
|
|
|
|
|
|
|
CHECK(handle->set_item("key", test_e) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(handle->get_item("key", test_e_read) == ESP_OK);
|
|
|
|
CHECK(test_e == test_e_read);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple correctly sets/gets int enum", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
enum class TestEnum : int {
|
|
|
|
FOO,
|
|
|
|
BAR
|
|
|
|
};
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2020-05-12 12:27:31 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
TestEnum test_e = TestEnum::BAR;
|
|
|
|
TestEnum test_e_read = TestEnum::FOO;
|
|
|
|
|
|
|
|
CHECK(handle->set_item("key", test_e) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(handle->get_item("key", test_e_read) == ESP_OK);
|
|
|
|
CHECK(test_e == test_e_read);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple correctly sets/gets int enum with negative values", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
enum class TestEnum : int {
|
|
|
|
FOO = -1,
|
|
|
|
BEER,
|
|
|
|
BAR
|
|
|
|
};
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2020-05-12 12:27:31 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
TestEnum test_e = TestEnum::FOO;
|
|
|
|
TestEnum test_e_read = TestEnum::BEER;
|
|
|
|
|
|
|
|
CHECK(handle->set_item("key", test_e) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(handle->get_item("key", test_e_read) == ESP_OK);
|
|
|
|
CHECK(test_e == test_e_read);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple correctly sets/gets uint8_t enum", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
enum class TestEnum : uint8_t {
|
|
|
|
FOO,
|
|
|
|
BAR
|
|
|
|
};
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2020-05-12 12:27:31 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
TestEnum test_e = TestEnum::BAR;
|
|
|
|
TestEnum test_e_read = TestEnum::FOO;
|
|
|
|
|
|
|
|
CHECK(handle->set_item("key", test_e) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(handle->get_item("key", test_e_read) == ESP_OK);
|
|
|
|
CHECK(test_e == test_e_read);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("NVSHandleSimple correctly sets/gets char enum", "[partition_mgr]")
|
|
|
|
{
|
|
|
|
enum class TestEnum : char {
|
|
|
|
FOO = -1,
|
|
|
|
BEER,
|
|
|
|
BAR
|
|
|
|
};
|
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
PartitionEmulationFixture f(0, 10);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
|
|
|
const uint32_t NVS_FLASH_SECTOR = 6;
|
|
|
|
const uint32_t NVS_FLASH_SECTOR_COUNT_MIN = 3;
|
2020-04-27 08:51:31 +08:00
|
|
|
f.emu.setBounds(NVS_FLASH_SECTOR, NVS_FLASH_SECTOR + NVS_FLASH_SECTOR_COUNT_MIN);
|
2020-05-12 12:27:31 +08:00
|
|
|
|
2020-04-27 08:51:31 +08:00
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->init_custom(&f.part, NVS_FLASH_SECTOR, NVS_FLASH_SECTOR_COUNT_MIN)
|
2020-05-12 12:27:31 +08:00
|
|
|
== ESP_OK);
|
|
|
|
|
|
|
|
NVSHandleSimple *handle;
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->open_handle(NVS_DEFAULT_PART_NAME, "ns_1", NVS_READWRITE, &handle) == ESP_OK);
|
|
|
|
|
|
|
|
TestEnum test_e = TestEnum::BAR;
|
|
|
|
TestEnum test_e_read = TestEnum::FOO;
|
|
|
|
|
|
|
|
CHECK(handle->set_item("key", test_e) == ESP_OK);
|
|
|
|
|
|
|
|
CHECK(handle->get_item("key", test_e_read) == ESP_OK);
|
|
|
|
CHECK(test_e == test_e_read);
|
|
|
|
|
|
|
|
delete handle;
|
|
|
|
|
|
|
|
REQUIRE(NVSPartitionManager::get_instance()->deinit_partition(NVS_DEFAULT_PART_NAME) == ESP_OK);
|
|
|
|
}
|