blob: 11fce8ea6a3c98c3f1b10ff675773d34d3e5a038 (
plain)
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
#!/usr/bin/env atf-sh
. $(atf_get_srcdir)/test_env.sh
init_tests \
setup_alpine_usage \
setup_alpine_quick \
setup_alpine_create_answerfile \
setup_alpine_kvm_clock \
setup_alpine_restart_network \
setup_alpine_answerfile_none
export WGETCONTENT="https://mirror.example.com"
setup_alpine_usage_body() {
test_usage setup-alpine
}
setup_alpine_quick_body() {
init_env
mkdir -p sys/class/net/lo sys/class/net/eth0
echo 1 >sys/class/net/lo/ifindex
echo 2 >sys/class/net/eth0/ifindex
echo down >sys/class/net/lo/operstate
echo down >sys/class/net/eth0/operstate
SSH_CONNECTION= atf_check -s exit:0 \
-o match:"openrc boot" \
-o match:"openrc default" \
-e empty \
setup-alpine -q
atf_check -s exit:0 \
rc-service --quiet hostname status
atf_check -s exit:0 \
rc-service --quiet networking status
}
setup_alpine_create_answerfile_body() {
init_env
atf_check -s exit:0 \
-o match:"Answer file answers has been created" \
setup-alpine -c answers
mkdir -p usr/share/zoneinfo/
touch usr/share/zoneinfo/UTC
echo 'USERSSHKEY="ssh-rsa blahbla user@example.com"' >> answers
echo 'ROOTSSHKEY="ssh-rsa blahbla user@example.com"' >> answers
SSH_CONNECTION= atf_check -s exit:0 \
-o match:"Starting hostname" \
-o match:"Starting mdev" \
-o match:"Added mirror" \
-o match:"adduser" \
-o match:"apk add.*openssh" \
setup-alpine -f answers
grep -x "ssh-rsa blahbla user@example.com" home/juser/.ssh/authorized_keys \
|| atf_fail "ssh key not set for juser"
grep -x "ssh-rsa blahbla user@example.com" root/.ssh/authorized_keys \
|| atf_fail "ssh key not set for root"
for file in home/juser root; do
grep -x "+.*$file" etc/apk/protected_paths.d/lbu.list \
|| atf_fail "$file was not added to lbu.list"
done
}
setup_alpine_kvm_clock_body() {
init_env
mkdir -p sys/class/net/lo sys/class/net/eth0
echo 1 >sys/class/net/lo/ifindex
echo 2 >sys/class/net/eth0/ifindex
echo down >sys/class/net/lo/operstate
echo down >sys/class/net/eth0/operstate
mkdir -p sys/devices/system/clocksource/clocksource0
echo kvm-clock > sys/devices/system/clocksource/clocksource0/current_clocksource
echo "none" > answers
KEYMAPOPTS=none \
HOSTNAMEOPTS=alpine \
INTERFACESOPTS=done \
DNSOPTS=none \
TIMEZONEOPTS=none \
PROXYOPTS=none \
APKREPOSOPTS=none \
USEROPTS=none \
SSHDOPTS=none \
DISKOPTS=none \
LBUOPTS=none \
APKCACHEOPTS=none \
\
atf_check -s exit:0 \
-o not-match:"Which NTP client to run" \
setup-alpine -e < answers
}
setup_alpine_restart_network_body() {
init_env
mkdir -p sys/class/net/lo sys/class/net/eth0
echo 1 >sys/class/net/lo/ifindex
echo 2 >sys/class/net/eth0/ifindex
echo down >sys/class/net/lo/operstate
echo down >sys/class/net/eth0/operstate
SSH_CONNECTION="::1 54984 ::1 22" atf_check -s exit:0 \
-o match:"openrc( -n)? boot" \
-e empty \
setup-alpine -q
atf_check -s exit:3 \
rc-service --quiet hostname status
atf_check -s exit:3 \
rc-service --quiet networking status
}
setup_alpine_answerfile_none_body() {
init_env
cat >opts<<-EOF
KEYMAPOPTS=none
HOSTNAMEOPTS=alpine
INTERFACESOPTS=none
DNSOPTS=none
TIMEZONEOPTS=none
PROXYOPTS=none
NTPOPTS=none
APKREPOSOPTS=none
USEROPTS=none
SSHDOPTS=none
DISKOPTS=none
LBUOPTS=none
APKCACHEOPTS=none
EOF
atf_check -s exit:0 \
-o match:"apk add" \
setup-alpine -e -f opts
for i in etc/network/interfaces etc/resolv.conf; do
if [ -e "$i" ]; then
atf_fail "$i should not been created"
fi
done
}
|