Browse Source

Add integration test for basic dinitcheck functionality

Davin McCall 4 years ago
parent
commit
7cd85c1134

+ 2 - 0
.gitignore

@@ -3,6 +3,7 @@
 /src/**/*.d
 /src/dinit
 /src/dinitctl
+/src/dinitcheck
 /src/shutdown
 /src/mconfig-gen
 /src/includes/mconfig.h
@@ -23,6 +24,7 @@
 /src/igr-tests/ps-environ/env-record
 /src/igr-tests/chain-to/recorded-output
 /src/igr-tests/restart/basic-ran
+/src/igr-tests/check-basic/output.txt
 
 # Generated man pages:
 /doc/manpages/*.5

+ 1 - 1
src/Makefile

@@ -53,7 +53,7 @@ $(objects): %.o: %.cc
 check:
 	$(MAKE) -C tests check
 
-check-igr: dinit dinitctl
+check-igr: dinit dinitctl dinitcheck
 	$(MAKE) -C igr-tests check-igr
 
 run-cppcheck:

+ 1 - 0
src/igr-tests/Makefile

@@ -9,3 +9,4 @@ igr-runner: igr-runner.cc
 clean:
 	rm -f igr-runner basic/basic-ran environ/env-record ps-environ/env-record chain-to/recorded-output
 	rm -f restart/basic-ran
+	rm -f check-basic/output.txt

+ 5 - 0
src/igr-tests/check-basic/expected.txt

@@ -0,0 +1,5 @@
+Checking service: boot...
+Service 'boot': Unknown setting: 'not-valid'.
+Service 'boot': run-as: Specified user id contains invalid numeric characters or is outside allowed range.
+Checking service: test1...
+Unable to load service 'test1': Service description not found.

+ 11 - 0
src/igr-tests/check-basic/run-test.sh

@@ -0,0 +1,11 @@
+#!/bin/sh
+
+../../dinitcheck -d sd > output.txt 2>&1
+
+STATUS=FAIL
+if cmp -s expected.txt output.txt; then
+   STATUS=PASS
+fi
+
+if [ $STATUS = PASS ]; then exit 0; fi
+exit 1

+ 3 - 0
src/igr-tests/check-basic/sd/boot

@@ -0,0 +1,3 @@
+depends-on=test1
+not-valid=some value
+run-as=9notanumber

+ 2 - 1
src/igr-tests/igr-runner.cc

@@ -12,7 +12,8 @@ extern char **environ;
 
 int main(int argc, char **argv)
 {
-    const char * const test_dirs[] = { "basic", "environ", "ps-environ", "chain-to", "force-stop", "restart" };
+    const char * const test_dirs[] = { "basic", "environ", "ps-environ", "chain-to", "force-stop", "restart",
+            "check-basic" };
     constexpr int num_tests = sizeof(test_dirs) / sizeof(test_dirs[0]);
 
     int passed = 0;