diff options
Diffstat (limited to '.travis/cmake-freebsd-stage1')
-rwxr-xr-x | .travis/cmake-freebsd-stage1 | 168 |
1 files changed, 45 insertions, 123 deletions
diff --git a/.travis/cmake-freebsd-stage1 b/.travis/cmake-freebsd-stage1 index a9d4c10e..6a88ed44 100755 --- a/.travis/cmake-freebsd-stage1 +++ b/.travis/cmake-freebsd-stage1 | |||
@@ -1,5 +1,7 @@ | |||
1 | #!/bin/sh | 1 | #!/bin/sh |
2 | 2 | ||
3 | # Download and initial setup of the FreeBSD VM | ||
4 | |||
3 | ACTION="$1" | 5 | ACTION="$1" |
4 | 6 | ||
5 | set -eux | 7 | set -eux |
@@ -7,8 +9,6 @@ set -eux | |||
7 | . .travis/cmake-freebsd-env.sh | 9 | . .travis/cmake-freebsd-env.sh |
8 | 10 | ||
9 | travis_install() { | 11 | travis_install() { |
10 | . .travis/cmake-freebsd-install.sh | ||
11 | |||
12 | git tag -l --sort=version:refname > GIT_TAGS | 12 | git tag -l --sort=version:refname > GIT_TAGS |
13 | 13 | ||
14 | OLD_PWD="$PWD" | 14 | OLD_PWD="$PWD" |
@@ -18,83 +18,55 @@ travis_install() { | |||
18 | 18 | ||
19 | # === Get the VM image, set it up and cache === | 19 | # === Get the VM image, set it up and cache === |
20 | 20 | ||
21 | # Create image if it's not cached or if this build script has changed | 21 | # Create image if it's not cached, or if this build script has changed, or a new toxcore tag was pushed |
22 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-env.sh" > /tmp/sha | 22 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-env.sh" > /tmp/sha |
23 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-install.sh" >> /tmp/sha | 23 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1" >> /tmp/sha |
24 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1" >> /tmp/sha | 24 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1.expect" >> /tmp/sha |
25 | if [ ! -f "./$IMAGE_NAME.tgz" ] || [ ! -f ./cmake-freebsd-stage1-all.sha256 ] || [ "`cat cmake-freebsd-stage1-all.sha256`" != "`cat /tmp/sha`" ]; then | 25 | if [ ! -f "./$IMAGE_NAME.tgz" ] || [ ! -f ./cmake-freebsd-stage1-all.sha256 ] || [ "$(cat cmake-freebsd-stage1-all.sha256)" != "$(cat /tmp/sha)" ] || ! diff -u ./GIT_TAGS "$OLD_PWD/GIT_TAGS"; then |
26 | |||
27 | rm -rf ./* | 26 | rm -rf ./* |
28 | 27 | ||
29 | # https://download.freebsd.org/ftp/releases/VM-IMAGES/11.2-RELEASE/amd64/Latest/ | 28 | while true; do |
30 | DL_SHA512="0c3c232c7023c5036daeb5fbf68c2ddecf9703c74e317afcf19da91e83d0afcc526785571e2868894ce15cdb56b74fafa1ce9fd216469db91e021ac2ef8911e5" | 29 | # Selecting random mirror from https://www.freebsd.org/doc/handbook/mirrors-ftp.html |
31 | # Selecting random mirror from https://www.freebsd.org/doc/handbook/mirrors-ftp.html | 30 | # Note that not all mirrors listed on that page are working, so we have removed them |
32 | # Note that not all mirrors listed on that page are working, so we have removed them | 31 | # There are no arrays in sh so we get a bit clever |
33 | # I'm so sorry, there are no arrays in sh and we are not using bash... | 32 | DL_MIRROR_1=1 |
34 | DL_MIRROR_1=1 | 33 | DL_MIRROR_2=2 |
35 | DL_MIRROR_2=4 | 34 | DL_MIRROR_3=3 |
36 | # There are 2 mirrors | 35 | DL_MIRROR_4=4 |
37 | DL_MIRROR_RANDOM=`expr $(date +%s) % 2 + 1` | 36 | DL_MIRROR_5=5 |
38 | DL_URL="ftp://ftp$(eval echo \$DL_MIRROR_$DL_MIRROR_RANDOM).us.freebsd.org/pub/FreeBSD/releases/VM-IMAGES/${FREEBSD_VERSION}-RELEASE/amd64/Latest/${IMAGE_NAME}.xz" | 37 | DL_MIRROR_6=6 |
39 | 38 | DL_MIRROR_7=7 | |
40 | wget "$DL_URL" | 39 | DL_MIRROR_8=10 |
41 | 40 | DL_MIRROR_9=11 | |
42 | if ! ( echo "$DL_SHA512 $IMAGE_NAME.xz" | sha512sum -c --status - ) ; then | 41 | DL_MIRROR_10=13 |
43 | echo "Error: sha512 of $IMAGE_NAME.xz doesn't match the known one" | 42 | DL_MIRROR_11=14 |
44 | exit 1 | 43 | |
44 | # There are 11 mirrors | ||
45 | DL_MIRROR_RANDOM=`expr $(date +%s) % 11 + 1` | ||
46 | DL_URL="ftp://ftp$(eval echo \$DL_MIRROR_$DL_MIRROR_RANDOM).us.freebsd.org/pub/FreeBSD/releases/VM-IMAGES/${FREEBSD_VERSION}-RELEASE/amd64/Latest/${IMAGE_NAME}.xz" | ||
47 | |||
48 | # Make sure there are no partial downloads from the previous loop iterations | ||
49 | rm -rf ./* | ||
50 | |||
51 | wget --tries 1 "$DL_URL" && break | ||
52 | done | ||
53 | |||
54 | if ! ( echo "$IMAGE_SHA512 $IMAGE_NAME.xz" | sha512sum -c --status - ) ; then | ||
55 | echo "Error: sha512 of $IMAGE_NAME.xz doesn't match the known one" | ||
56 | exit 1 | ||
45 | fi | 57 | fi |
46 | 58 | ||
47 | unxz "$IMAGE_NAME.xz" | 59 | unxz "$IMAGE_NAME.xz" |
48 | 60 | ||
49 | # With this we don't have to guess how long a command will run for and sleeping | 61 | sudo apt-get update |
50 | # for that amount of time, risking either under sleeping or over sleeping, instead | 62 | sudo apt-get install -y qemu screen expect |
51 | # we will sleep exactly until the command is finished by printing out a unique | ||
52 | # string after the command is executed and then checking if it was printed. | ||
53 | execute_shell_and_wait() | ||
54 | { | ||
55 | # $RANDOM is a bash built-in, so we try to avoid name collision here by using ugly RANDOM_STR name | ||
56 | RANDOM_STR=$(< /dev/urandom tr -dc _A-Za-z0-9 | head -c16) | ||
57 | send_keys "$1;echo $RANDOM_STR | ||
58 | |||
59 | " | ||
60 | # \[1B is a control escape sequence for a new line in the terminal. | ||
61 | # We want to wait for <new-line>$RANDOM_STR instead of just $RANDOM_STR because | ||
62 | # $RANDOM_STR we have inputted with send_keys above would appear in the screenlog.0 | ||
63 | # file and we don't want to match our input, we want to match the echo's output. | ||
64 | # The .\? optionally matches any character. Sometimes it happens that there is some | ||
65 | # random character inserved between the new line control escape sequence and $RANDOM_STR. | ||
66 | wait_for "\[1B.\?$RANDOM_STR" | ||
67 | } | ||
68 | |||
69 | start_vm | ||
70 | |||
71 | # Login as root user | ||
72 | send_keys 'root | ||
73 | |||
74 | ' | ||
75 | |||
76 | # Wait for the prompt | ||
77 | wait_for "root@.*:~" | ||
78 | 63 | ||
79 | # Configure network, ssh and start changing password | 64 | # The downloaded image has little free disk space |
80 | execute_shell_and_wait 'echo "ifconfig_em0=DHCP" >> /etc/rc.conf' | 65 | qemu-img resize -f raw "$IMAGE_NAME" +5G |
81 | execute_shell_and_wait 'echo "Port 22" >> /etc/ssh/sshd_config' | ||
82 | execute_shell_and_wait 'echo "PermitRootLogin yes" >> /etc/ssh/sshd_config' | ||
83 | execute_shell_and_wait 'echo "PasswordAuthentication yes" >> /etc/ssh/sshd_config' | ||
84 | execute_shell_and_wait 'echo "PermitEmptyPasswords yes" >> /etc/ssh/sshd_config' | ||
85 | execute_shell_and_wait 'echo "sshd_enable=YES" >> /etc/rc.conf' | ||
86 | send_keys 'sh /etc/rc.d/netif restart && sh /etc/rc.d/sshd start && passwd | ||
87 | ' | ||
88 | 66 | ||
89 | # Wait for the password prompt | 67 | NPROC=$NPROC SSH_PORT=$SSH_PORT IMAGE_NAME="$IMAGE_NAME" screen "$OLD_PWD/.travis/cmake-freebsd-stage1.expect" |
90 | wait_for "Changing local password for root" | ||
91 | 68 | ||
92 | # Reset password to empty for the passwordless ssh to work | 69 | start_vm |
93 | send_keys ' | ||
94 | ' | ||
95 | wait_for "New Password" | ||
96 | send_keys ' | ||
97 | ' | ||
98 | 70 | ||
99 | # Update system | 71 | # Update system |
100 | RUN env PAGER=cat env ASSUME_ALWAYS_YES=YES freebsd-update --not-running-from-cron fetch | 72 | RUN env PAGER=cat env ASSUME_ALWAYS_YES=YES freebsd-update --not-running-from-cron fetch |
@@ -117,7 +89,6 @@ travis_install() { | |||
117 | gmake \ | 89 | gmake \ |
118 | cmake \ | 90 | cmake \ |
119 | pkgconf \ | 91 | pkgconf \ |
120 | opencv \ | ||
121 | portaudio \ | 92 | portaudio \ |
122 | libsndfile \ | 93 | libsndfile \ |
123 | texinfo \ | 94 | texinfo \ |
@@ -130,60 +101,11 @@ travis_install() { | |||
130 | # Create cache | 101 | # Create cache |
131 | tar -Sczvf "$IMAGE_NAME.tgz" "$IMAGE_NAME" | 102 | tar -Sczvf "$IMAGE_NAME.tgz" "$IMAGE_NAME" |
132 | rm "$IMAGE_NAME" | 103 | rm "$IMAGE_NAME" |
133 | rm screenlog.0 | ||
134 | |||
135 | cp "$OLD_PWD/GIT_TAGS" . | ||
136 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-env.sh" > cmake-freebsd-stage1-all.sha256 | ||
137 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-install.sh" >> cmake-freebsd-stage1-all.sha256 | ||
138 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1" >> cmake-freebsd-stage1-all.sha256 | ||
139 | |||
140 | ls -lh | ||
141 | fi | ||
142 | |||
143 | # === Update the image on new version (tag) of toxcore === | ||
144 | |||
145 | if ! diff -u ./GIT_TAGS "$OLD_PWD/GIT_TAGS" ; then | ||
146 | # Extract the cached image | ||
147 | tar -Sxzvf "$IMAGE_NAME.tgz" | ||
148 | |||
149 | start_vm | ||
150 | |||
151 | # Log in. | ||
152 | # Although qemu prints "login:" and "Password:" lines, they are not written into the screen's log | ||
153 | # file for some reason (perhaps not enough text to flush the buffer to a file?), so we can't use | ||
154 | # wait_for on them, we just use sleep to add hopefully enough delay. | ||
155 | sleep 5 | ||
156 | # "login:" | ||
157 | send_keys 'root | ||
158 | |||
159 | ' | ||
160 | sleep 5 | ||
161 | # "Password:" | ||
162 | send_keys ' | ||
163 | |||
164 | ' | ||
165 | # Wait for the prompt | ||
166 | wait_for "root@.* ~" | ||
167 | |||
168 | # Update system | ||
169 | RUN PAGER=cat ASSUME_ALWAYS_YES=YES freebsd-update --not-running-from-cron fetch | ||
170 | RUN PAGER=cat ASSUME_ALWAYS_YES=YES freebsd-update --not-running-from-cron install || true | ||
171 | |||
172 | # Update packages | ||
173 | RUN PAGER=cat ASSUME_ALWAYS_YES=YES pkg upgrade | ||
174 | |||
175 | # === Cache the updated VM image === | ||
176 | |||
177 | stop_vm | ||
178 | |||
179 | # Create/Update cache | ||
180 | rm "$IMAGE_NAME.tgz" | ||
181 | tar -Sczvf "$IMAGE_NAME.tgz" "$IMAGE_NAME" | ||
182 | rm "$IMAGE_NAME" | ||
183 | rm screenlog.0 | ||
184 | 104 | ||
185 | cp "$OLD_PWD/GIT_TAGS" . | 105 | cp "$OLD_PWD/GIT_TAGS" . |
186 | 106 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-env.sh" > cmake-freebsd-stage1-all.sha256 | |
107 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1" >> cmake-freebsd-stage1-all.sha256 | ||
108 | sha256sum "$OLD_PWD/.travis/cmake-freebsd-stage1.expect" >> cmake-freebsd-stage1-all.sha256 | ||
187 | ls -lh | 109 | ls -lh |
188 | fi | 110 | fi |
189 | 111 | ||