mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-23 01:47:33 +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.
		
			
				
	
	
		
			216 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			216 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * testrunner.c
 | |
|  *
 | |
|  *  Created on: Jun 18, 2013
 | |
|  *      Author: petera
 | |
|  */
 | |
| 
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <stdlib.h>
 | |
| #include <string.h>
 | |
| 
 | |
| #include <sys/types.h>
 | |
| #include <sys/stat.h>
 | |
| #include <fcntl.h>
 | |
| //#include <dirent.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| #include "esp_common.h"
 | |
| #include "testrunner.h"
 | |
| 
 | |
| static struct {
 | |
|   test *tests;
 | |
|   test *_last_test;
 | |
|   int test_count;
 | |
|   void (*on_stop)(test *t);
 | |
|   test_res *failed;
 | |
|   test_res *failed_last;
 | |
|   test_res *stopped;
 | |
|   test_res *stopped_last;
 | |
|   FILE *spec;
 | |
|   char incl_filter[256];
 | |
|   char excl_filter[256];
 | |
| } test_main;
 | |
| 
 | |
| void test_init(void (*on_stop)(test *t)) {
 | |
|   test_main.on_stop = on_stop;
 | |
| }
 | |
| 
 | |
| static char check_spec(char *name) {
 | |
|   if (test_main.spec) {
 | |
|     fseek(test_main.spec, 0, SEEK_SET);
 | |
|     char *line = NULL;
 | |
|     size_t sz;
 | |
|     ssize_t read;
 | |
|     while ((read = __getline(&line, &sz, test_main.spec)) != -1) {
 | |
|       if (strncmp(line, name, strlen(line)-1) == 0) {
 | |
|         free(line);
 | |
|         return 1;
 | |
|       }
 | |
|     }
 | |
|     free(line);
 | |
|     return 0;
 | |
|   } else {
 | |
|     return 1;
 | |
|   }
 | |
| }
 | |
| 
 | |
| static char check_incl_filter(char *name) {
 | |
|   if (strlen(test_main.incl_filter)== 0) return 1;
 | |
|   return strstr(name, test_main.incl_filter) == 0 ? 0 : 1;
 | |
| }
 | |
| 
 | |
| static char check_excl_filter(char *name) {
 | |
|   if (strlen(test_main.excl_filter)== 0) return 1;
 | |
|   return strstr(name, test_main.excl_filter) == 0 ? 1 : 0;
 | |
| }
 | |
| 
 | |
| void add_test(test_f f, char *name, void (*setup)(test *t), void (*teardown)(test *t)) {
 | |
|   if (f == 0) return;
 | |
|   if (!check_spec(name)) return;
 | |
|   if (!check_incl_filter(name)) return;
 | |
|   if (!check_excl_filter(name)) return;
 | |
|   DBGT("adding test %s\n", name);
 | |
|   test *t = malloc(sizeof(test));
 | |
|   MALLOC_CHECK_RETURN(t != NULL, sizeof(test));
 | |
|   memset(t, 0, sizeof(test));
 | |
|   t->f = f;
 | |
|   strcpy(t->name, name);
 | |
|   t->setup = setup;
 | |
|   t->teardown = teardown;
 | |
|   if (test_main.tests == 0) {
 | |
|     test_main.tests = t;
 | |
|   } else {
 | |
|     test_main._last_test->_next = t;
 | |
|   }
 | |
|   test_main._last_test = t;
 | |
|   test_main.test_count++;
 | |
| }
 | |
| 
 | |
| static void add_res(test *t, test_res **head, test_res **last) {
 | |
|   test_res *tr = malloc(sizeof(test_res));
 | |
|   MALLOC_CHECK_RETURN(t != NULL, sizeof(test));
 | |
|   memset(tr,0,sizeof(test_res));
 | |
|   strcpy(tr->name, t->name);
 | |
|   if (*head == 0) {
 | |
|     *head = tr;
 | |
|   } else {
 | |
|     (*last)->_next = tr;
 | |
|   }
 | |
|   *last = tr;
 | |
| }
 | |
| 
 | |
| static void dump_res(test_res **head) {
 | |
|   test_res *tr = (*head);
 | |
|   while (tr) {
 | |
|     test_res *next_tr = tr->_next;
 | |
|     printf("  %s\n", tr->name);
 | |
|     free(tr);
 | |
|     tr = next_tr;
 | |
|   }
 | |
| }
 | |
| 
 | |
| int run_tests(int argc, char **args) {
 | |
|   memset(&test_main, 0, sizeof(test_main));
 | |
|   int arg;
 | |
|   int incl_filter = 0;
 | |
|   int excl_filter = 0;
 | |
|   for (arg = 0; arg < argc; arg++) {
 | |
|     if (strlen(args[arg]) == 0) continue;
 | |
|     if (0 == strcmp("-f", args[arg])) {
 | |
|       incl_filter = 1;
 | |
|       continue;
 | |
|     }
 | |
|     if (0 == strcmp("-e", args[arg])) {
 | |
|       excl_filter = 1;
 | |
|       continue;
 | |
|     }
 | |
|     if (incl_filter) {
 | |
|       strcpy(test_main.incl_filter, args[arg]);
 | |
|       incl_filter = 0;
 | |
|     } else if (excl_filter) {
 | |
|       strcpy(test_main.excl_filter, args[arg]);
 | |
|       excl_filter = 0;
 | |
|     } else {
 | |
|       printf("running tests from %s\n", args[arg]);
 | |
|       FILE *fd = fopen(args[1], "r");
 | |
|       if (fd == NULL) {
 | |
|         printf("%s not found\n", args[arg]);
 | |
|         return -2;
 | |
|       }
 | |
|       test_main.spec = fd;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   DBGT("adding suites...\n");
 | |
|   add_suites();
 | |
|   DBGT("%i tests added\n", test_main.test_count);
 | |
|   if (test_main.spec) {
 | |
|     fclose(test_main.spec);
 | |
|   }
 | |
| 
 | |
|   if (test_main.test_count == 0) {
 | |
|     printf("No tests to run\n");
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   int fd_success = open("_tests_ok", O_APPEND | O_TRUNC | O_CREAT | O_RDWR, S_IRUSR | S_IWUSR);
 | |
|   int fd_bad = open("_tests_fail", O_APPEND | O_TRUNC | O_CREAT | O_RDWR, S_IRUSR | S_IWUSR);
 | |
| 
 | |
|   DBGT("running tests...\n");
 | |
|   int ok = 0;
 | |
|   int failed = 0;
 | |
|   int stopped = 0;
 | |
|   test *cur_t = test_main.tests;
 | |
|   int i = 1;
 | |
|   while (cur_t) {
 | |
|     cur_t->setup(cur_t);
 | |
|     test *next_test = cur_t->_next;
 | |
|     DBGT("TEST %i/%i : running test %s\n", i, test_main.test_count, cur_t->name);
 | |
|     i++;
 | |
|     int res = cur_t->f(cur_t);
 | |
|     cur_t->test_result = res;
 | |
|     cur_t->teardown(cur_t);
 | |
|     int fd = res == TEST_RES_OK ? fd_success : fd_bad;
 | |
|     write(fd, cur_t->name, strlen(cur_t->name));
 | |
|     write(fd, "\n", 1);
 | |
|     switch (res) {
 | |
|     case TEST_RES_OK:
 | |
|       ok++;
 | |
|       printf("  .. ok\n");
 | |
|       break;
 | |
|     case TEST_RES_FAIL:
 | |
|       failed++;
 | |
|       printf("  .. FAILED\n");
 | |
|       if (test_main.on_stop) test_main.on_stop(cur_t);
 | |
|       add_res(cur_t, &test_main.failed, &test_main.failed_last);
 | |
|       break;
 | |
|     case TEST_RES_ASSERT:
 | |
|       stopped++;
 | |
|       printf("  .. ABORTED\n");
 | |
|       if (test_main.on_stop) test_main.on_stop(cur_t);
 | |
|       add_res(cur_t, &test_main.stopped, &test_main.stopped_last);
 | |
|       break;
 | |
|     }
 | |
|     free(cur_t);
 | |
|     cur_t = next_test;
 | |
|   }
 | |
|   close(fd_success);
 | |
|   close(fd_bad);
 | |
|   DBGT("ran %i tests\n", test_main.test_count);
 | |
|   printf("Test report, %i tests\n", test_main.test_count);
 | |
|   printf("%i succeeded\n", ok);
 | |
|   printf("%i failed\n", failed);
 | |
|   dump_res(&test_main.failed);
 | |
|   printf("%i stopped\n", stopped);
 | |
|   dump_res(&test_main.stopped);
 | |
|   if (ok < test_main.test_count) {
 | |
|     printf("\nFAILED\n");
 | |
|     return -1;
 | |
|   } else {
 | |
|     printf("\nALL TESTS OK\n");
 | |
|     return 0;
 | |
|   }
 | |
| }
 |