-
Notifications
You must be signed in to change notification settings - Fork 67
/
build_test.sh
93 lines (89 loc) · 2.88 KB
/
build_test.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/bin/sh
IPREX4='([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
# build
docker build -t ppdns .
v4check() {
if echo "$1" | grep -v "timed out" | grep -v "127.0.0.1" | grep -E "$IPREX4"; then
echo "$2" pass.
else
echo "$2" failed:"$1"
exit
fi
}
docker run -d --name test1 \
-e HTTP_FILE=yes \
-e USE_HOSTS=yes \
-e RULES_TTL=1 \
--add-host host.paopaodns:111.111.111.111 \
ppdns
sleep 5
docker exec test1 sh -c "echo "force_ttl_rules.paopaodns@@1.2.3.4" > /data/force_ttl_rules.txt"
# base test
t1=$(docker exec test1 dig www.taobao.com @127.0.0.1 -p53 A +short)
v4check "$t1" CN-53
t2=$(docker exec test1 dig www.taobao.com @127.0.0.1 -p5301 A +short)
v4check "$t2" CN-5301
t3=$(docker exec test1 dig www.taobao.com @127.0.0.1 -p5302 A +short)
v4check "$t3" CN-5302
docker exec test1 dig www.taobao.com @127.0.0.1 -p5304 A
sleep 5
t4=$(docker exec test1 dig www.taobao.com @127.0.0.1 -p5304 A +short)
v4check "$t4" CN-5304
t5=$(docker exec test1 dig www.google.com @127.0.0.1 -p53 A +short)
v4check "$t5" NOCN-53
t6=$(docker exec test1 dig www.google.com @127.0.0.1 -p5301 A +short)
v4check "$t6" NOCN-5301
t7=$(docker exec test1 dig www.google.com @127.0.0.1 -p5302 A +short)
v4check "$t7" NOCN-5302
t8=$(docker exec test1 dig www.google.com @127.0.0.1 -p5304 A +short)
v4check "$t8" NOCN-5304
t9=$(docker exec test1 dig host.paopaodns @127.0.0.1 -p53 A +short)
v4check "$t9" USE_HOSTS
t10=$(docker exec test1 dig force_ttl_rules.paopaodns @127.0.0.1 -p53 A +short)
v4check "$t10" force_ttl_rules
if docker exec test1 mosdns curl http://127.0.0.1:7889 | grep -q Country-only-cn-private.mmdb; then
echo HTTP_FILE pass.
else
exit
fi
docker exec test1 apk add socat
docker exec test1 sh -c "echo 'example.com' | socat - UNIX-CONNECT:/tmp/flush.sock && echo flush_ok_flag >>/etc/os-release"
if docker exec test1 cat /etc/os-release | grep -q flush_ok_flag; then
echo flush_ok_flag pass.
else
exit
fi
docker rm -f test1
docker run --name test2 \
-e USE_MARK_DATA=yes \
-e AUTO_FORWARD=yes \
-e CUSTOM_FORWARD=8.8.8.8:53 \
ppdns &
sleep 15
t11=$(docker exec test2 dig www.youtube.com @127.0.0.1 -p53 A +short)
v4check "$t11" AUTO_FORWARD_OK
docker rm -f test2
docker run --name test3 \
-e USE_MARK_DATA=yes \
-e AUTO_FORWARD=yes \
-e ADDINFO=yes \
-e CUSTOM_FORWARD=9.8.7.6:53 \
ppdns &
sleep 15
t12=$(docker exec test3 dig www.youtube.com @127.0.0.1 -p53 A)
if echo "$t12" | grep REFUSED; then
echo CUSTOM_FORWARD_BAD pass.
else
echo CUSTOM_FORWARD_BAD failed:"$t12"
exit
fi
if docker exec test3 redis-cli -s /tmp/redis.sock info | grep -q human; then
echo redis pass.
else
echo redis failed.
exit
fi
docker rm -f test3
# pass check
echo ALL TEST PASSED.
touch build_test_ok