mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-25 05:25:06 +08:00 
			
		
		
		
	 3ca6af5da6
			
		
	
	3ca6af5da6
	
	
	
		
			
			1. Add libssc.a, simple serial console lib. 2. Add libspiffs.a, SPI file system. 3. Add libwps.a to support WPS. 4. Add libespconn.a, Espressif connection lib. 5. Add libespnow.a to support Espressif ESP-NOW. 6. Add libmesh.a, Espressif mesh. 7. Add libnopoll.a, websocket. 8. Add make_lib.sh in "third_party" folder. 9. Add modem-sleep & light-sleep supported. 10. Update libcirom.a to support float IO. 11. Update gen_misc.sh & gen_misc.bat. 12. Update header files, add comments in doxygen style. 13. Update libsmartconfig.a to version 2.5.2. 14. Update libssl.a. 15. Updates driver (PWM/UART/GPIO/SPI/Hardware timer). 16. Update open source codes of third_party. 17. Modify "ld" files, "dram0 len" should be 0x18000 in RTOS SDK. 18. Remove header files in extra_include, which are already in compile folder. 19. Other APIs sync from non-OS SDK, more details in documentation "20B-ESP8266__RTOS_SDK_API Reference". 20. Other optimization to make the SDK more stable.
		
			
				
	
	
		
			152 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * testrunner.h
 | |
|  *
 | |
|  *  Created on: Jun 19, 2013
 | |
|  *      Author: petera
 | |
|  */
 | |
| 
 | |
| /*
 | |
| 
 | |
| SUITE(mysuite)
 | |
| 
 | |
| void setup(test *t) {}
 | |
| 
 | |
| void teardown(test *t) {}
 | |
| 
 | |
| TEST(mytest) {
 | |
|   printf("mytest runs now..\n");
 | |
|   return 0;
 | |
| } TEST_END(mytest)
 | |
| 
 | |
| SUITE_END(mysuite)
 | |
| 
 | |
| 
 | |
| 
 | |
| SUITE(mysuite2)
 | |
| 
 | |
| void setup(test *t) {}
 | |
| 
 | |
| void teardown(test *t) {}
 | |
| 
 | |
| TEST(mytest2a) {
 | |
|   printf("mytest2a runs now..\n");
 | |
|   return 0;
 | |
| } TEST_END(mytest2a)
 | |
| 
 | |
| TEST(mytest2b) {
 | |
|   printf("mytest2b runs now..\n");
 | |
|   return 0;
 | |
| } TEST_END(mytest2b)
 | |
| 
 | |
| SUITE_END(mysuite2)
 | |
| 
 | |
| 
 | |
| 
 | |
| void add_suites() {
 | |
|   ADD_SUITE(mysuite);
 | |
|   ADD_SUITE(mysuite2);
 | |
| }
 | |
|  */
 | |
| 
 | |
| #ifndef TESTRUNNER_H_
 | |
| #define TESTRUNNER_H_
 | |
| 
 | |
| #define TEST_RES_OK   0
 | |
| #define TEST_RES_FAIL -1
 | |
| #define TEST_RES_ASSERT -2
 | |
| 
 | |
| struct test_s;
 | |
| 
 | |
| typedef int (*test_f)(struct test_s *t);
 | |
| 
 | |
| typedef struct test_s {
 | |
|   test_f f;
 | |
|   char name[64];
 | |
|   void *data;
 | |
|   void (*setup)(struct test_s *t);
 | |
|   void (*teardown)(struct test_s *t);
 | |
|   struct test_s *_next;
 | |
|   unsigned char test_result;
 | |
| } test;
 | |
| 
 | |
| typedef struct test_res_s {
 | |
|   char name[256];
 | |
|   struct test_res_s *_next;
 | |
| } test_res;
 | |
| 
 | |
| #define MALLOC_CHECK(x, y) if (!(x)) { \
 | |
|   printf("  MALLOC %i FAIL %s:%i, FREE %i\n", y, __FILE__, __LINE__, system_get_free_heap_size()); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| 
 | |
| #define MALLOC_CHECK_RETURN(x, y) if (!(x)) { \
 | |
|   printf("  MALLOC %i FAIL %s:%i, FREE %i\n", y, __FILE__, __LINE__, system_get_free_heap_size()); \
 | |
|   return; \
 | |
| }
 | |
| 
 | |
| #define MALLOC_CHECK_RETURN_1(x, y) if (!(x)) { \
 | |
|   printf("  MALLOC %i FAIL %s:%i, FREE %i\n", y, __FILE__, __LINE__, system_get_free_heap_size()); \
 | |
|   return -1;  \
 | |
| }
 | |
| 
 | |
| #define TEST_CHECK(x) if (!(x)) { \
 | |
|   printf("  TEST FAIL %s:%i\n", __FILE__, __LINE__); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_EQ(x, y) if ((x) != (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i != %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_NEQ(x, y) if ((x) == (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i == %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_GT(x, y) if ((x) <= (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i <= %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_LT(x, y) if ((x) >= (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i >= %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_GE(x, y) if ((x) < (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i < %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_CHECK_LE(x, y) if ((x) > (y)) { \
 | |
|   printf("  TEST FAIL %s:%i, %i > %i\n", __FILE__, __LINE__, (x), (y)); \
 | |
|   goto __fail_stop; \
 | |
| }
 | |
| #define TEST_ASSERT(x) if (!(x)) { \
 | |
|   printf("  TEST ASSERT %s:%i\n", __FILE__, __LINE__); \
 | |
|   goto __fail_assert; \
 | |
| }
 | |
| 
 | |
| #define DBGT(...) os_printf(__VA_ARGS__)
 | |
| 
 | |
| #define str(s) #s
 | |
| 
 | |
| #define SUITE(sui) \
 | |
|   extern void __suite_##sui() {
 | |
| #define SUITE_END(sui) \
 | |
|   }
 | |
| #define ADD_SUITE(sui) \
 | |
|   __suite_##sui();
 | |
| #define TEST(tf) \
 | |
|   int tf(struct test_s *t) { do
 | |
| #define TEST_END(tf) \
 | |
|   while(0); \
 | |
|   __fail_stop: return TEST_RES_FAIL; \
 | |
|   __fail_assert: return TEST_RES_ASSERT; \
 | |
|   } \
 | |
|   add_test(tf, str(tf), setup, teardown);
 | |
| 
 | |
| 
 | |
| void add_suites();
 | |
| void test_init(void (*on_stop)(test *t));
 | |
| void add_test(test_f f, char *name, void (*setup)(test *t), void (*teardown)(test *t));
 | |
| // returns 0 if all tests ok, -1 if any test failed, -2 on badness
 | |
| int run_tests(int argc, char **args);
 | |
| 
 | |
| #endif /* TESTRUNNER_H_ */
 |