test/security: add inline inbound IPsec cases
[dpdk.git] / app / test / test_eal_flags.c
index d7f4c2c..68deb86 100644 (file)
@@ -9,6 +9,94 @@
 
 #include <string.h>
 #include <stdarg.h>
+
+#ifdef RTE_EXEC_ENV_WINDOWS
+static int
+test_missing_c_flag(void)
+{
+       printf("missing_c_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_main_lcore_flag(void)
+{
+       printf("main_lcore_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_invalid_n_flag(void)
+{
+       printf("invalid_n_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_no_hpet_flag(void)
+{
+       printf("no_hpet_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_no_huge_flag(void)
+{
+       printf("no_huge_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_allow_flag(void)
+{
+       printf("allow_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_invalid_b_flag(void)
+{
+       printf("invalid_b_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_invalid_vdev_flag(void)
+{
+       printf("invalid_vdev_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_invalid_r_flag(void)
+{
+       printf("invalid_r_flag not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_memory_flags(void)
+{
+       printf("memory_flags not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_file_prefix(void)
+{
+       printf("file_prefix not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+static int
+test_misc_flags(void)
+{
+       printf("misc_flags not supported on Windows, skipping test\n");
+       return TEST_SKIPPED;
+}
+
+#else
+
 #include <libgen.h>
 #include <stdlib.h>
 #include <errno.h>
@@ -1122,6 +1210,11 @@ test_file_prefix(void)
                DEFAULT_MEM_SIZE, "--single-file-segments",
                "--file-prefix=" memtest1 };
 
+       /* primary process with memtest1 and --huge-unlink=never mode */
+       const char * const argv9[] = {prgname, "-m",
+               DEFAULT_MEM_SIZE, "--huge-unlink=never",
+               "--file-prefix=" memtest1 };
+
        /* check if files for current prefix are present */
        if (process_hugefiles(prefix, HUGEPAGE_CHECK_EXISTS) != 1) {
                printf("Error - hugepage files for %s were not created!\n", prefix);
@@ -1290,6 +1383,25 @@ test_file_prefix(void)
                return -1;
        }
 
+       /* this process will run with --huge-unlink,
+        * so it should not remove hugepage files when it exits
+        */
+       if (launch_proc(argv9) != 0) {
+               printf("Error - failed to run with --huge-unlink=never\n");
+               return -1;
+       }
+
+       /* check if hugefiles for memtest1 are present */
+       if (process_hugefiles(memtest1, HUGEPAGE_CHECK_EXISTS) == 0) {
+               printf("Error - hugepage files for %s were deleted!\n",
+                               memtest1);
+               return -1;
+       }
+       if (process_hugefiles(memtest1, HUGEPAGE_DELETE) != 1) {
+               printf("Error - deleting hugepages failed!\n");
+               return -1;
+       }
+
        return 0;
 }
 
@@ -1498,6 +1610,8 @@ test_memory_flags(void)
        return 0;
 }
 
+#endif /* !RTE_EXEC_ENV_WINDOWS */
+
 REGISTER_TEST_COMMAND(eal_flags_c_opt_autotest, test_missing_c_flag);
 REGISTER_TEST_COMMAND(eal_flags_main_opt_autotest, test_main_lcore_flag);
 REGISTER_TEST_COMMAND(eal_flags_n_opt_autotest, test_invalid_n_flag);