added test cases for image start offset and fix
This commit is contained in:
@ -3,62 +3,175 @@
|
||||
|
||||
#include "mesh_ota.h"
|
||||
|
||||
#include "test_image_hex.h"
|
||||
|
||||
|
||||
|
||||
// ### ### ### distinguish newer image version ### ### ###
|
||||
|
||||
TEST_CASE("Remote got patch", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "1.2.3"; //current running image
|
||||
char versionRemote[] = "1.2.4"; //image from server
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Remote got minor", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "1.2.3"; //current running image
|
||||
char versionRemote[] = "1.3.3"; //image from server
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Remote got major", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "1.2.3"; //current running image
|
||||
char versionRemote[] = "2.2.3"; //image from server
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Local got patch", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "1.2.4"; //current running image
|
||||
char versionRemote[] = "1.2.3"; //image from server
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Local got minor", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "1.3.3"; //current running image
|
||||
char versionRemote[] = "1.2.3"; //image from server
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Local got major", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "2.2.3"; //current running image
|
||||
char versionRemote[] = "1.2.3"; //image from server
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_FALSE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Remote got alpha and patch", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "2.2.3"; //current running image
|
||||
char versionRemote[] = "a2.2.4"; //image from server
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
TEST_CASE("Remote got max", "[distinguish newer image version]")
|
||||
{
|
||||
char versionLocal[] = "2.2.3"; //current running image
|
||||
char versionRemote[] = "999.999.999"; //image from server
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
TEST_ASSERT_TRUE( bNewerVersion(versionLocal, versionRemote) );
|
||||
}
|
||||
|
||||
// ### ### ### find start offset in firmware image ### ### ###
|
||||
|
||||
TEST_CASE("with http response + 0.0.1", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithHttpRespone0_0_1)/sizeof(dataWithHttpRespone0_0_1[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithHttpRespone0_0_1, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(305, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("without http response + 0.0.1", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithoutHttpRespone0_0_1)/sizeof(dataWithoutHttpRespone0_0_1[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithoutHttpRespone0_0_1, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(0, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
TEST_CASE("with http response + 999.999.999", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithHttpRespone999_999_999)/sizeof(dataWithHttpRespone999_999_999[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithHttpRespone999_999_999, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(305, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("without http response + 999.999.999", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithoutHttpRespone999_999_999)/sizeof(dataWithoutHttpRespone999_999_999[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithoutHttpRespone999_999_999, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(0, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("with http response + 999.9.999", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithHttpRespone999_9_999)/sizeof(dataWithHttpRespone999_9_999[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithHttpRespone999_9_999, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(302, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("with http response + 999.99.999", "[find start offset in firmware image]")
|
||||
{
|
||||
uint32_t u32StartOffset;
|
||||
uint32_t u32DataLenght = sizeof(dataWithHttpRespone999_99_999)/sizeof(dataWithHttpRespone999_99_999[0]);
|
||||
esp_err_t err = errFindImageStart(dataWithHttpRespone999_99_999, &u32DataLenght, &u32StartOffset);
|
||||
if(err == ESP_OK)
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(299, u32StartOffset);
|
||||
}
|
||||
else
|
||||
{
|
||||
TEST_ASSERT_EQUAL_INT(ESP_OK, err);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user