2 # DO NOT EDIT THIS FILE IN MASTER. ONLY EDIT IT IN THE OLDEST SUPPORTED
3 # BRANCH, THEN MERGE FORWARD.
6 # This file controls how gitlab validates Tor commits and merge requests.
8 # It is primarily based on a set of scripts and configurations by
9 # Hans-Christoph Steiner. It only copies parts of those scripts and
10 # configurations for now. If you want a new piece of functionality
11 # (more debians, more fedoras, android support) then you shouldn't
12 # start from scratch: have a look at the original ticket, at
13 # https://gitlab.torproject.org/tpo/core/tor/-/issues/32193 !
15 # The file to copy from is
16 # https://gitlab.torproject.org/tpo/core/tor/-/merge_requests/96/diffs#diff-content-587d266bb27a4dc3022bbed44dfa19849df3044c
18 # Having said that, if there is anything really stupid here, don't
19 # blame it on Hans-Christoph! Tor probably added it on their own.
21 # Copyright 2020, The Tor Project, Inc.
22 # See LICENSE for licence information.
24 # These variables are set everywhere, unconditionally.
29 # This template is for exporting ephemeral things from the scripts. By
30 # convention we expect our scripts to copy stuff into artifacts/, rather than
31 # having a big list of files that be treated as artifacts.
32 .artifacts-template: &artifacts-template
34 name: "${CI_PROJECT_PATH}_${CI_JOB_STAGE}_${CI_COMMIT_REF_NAME}_${CI_COMMIT_SHA}"
40 # This template should be usable on any system that's based on apt.
41 .apt-template: &apt-template |
43 echo Etc/UTC > /etc/timezone
45 export APT_CACHE_DIR="$(pwd)/apt-cache"
47 'APT::Install-Recommends "0";' \
48 'APT::Install-Suggests "0";' \
49 'APT::Acquire::Retries "20";' \
50 'APT::Get::Assume-Yes "true";' \
51 'Dpkg::Use-Pty "0";' \
52 "Dir::Cache::Archives \"${APT_CACHE_DIR}\"; " \
53 >> /etc/apt/apt.conf.d/99gitlab
57 # This template sets us up for Debian system in particular.
58 .debian-template: &debian-template
59 <<: *artifacts-template
61 DEBIAN_FRONTEND: "noninteractive"
62 # TODO: Using "cache" in this way speeds up our downloads. It would be
63 # even better, though, to start with a pre-upgraded debian image.
65 # TODO: Will we have to do this differently once we have more than one
66 # debian version that we're using?
73 # Install patches unconditionally.
87 # Install patches that we only need for some use cases.
88 - if [ "$ASCIIDOC" = yes ]; then apt-get install asciidoc xmlto; fi
89 - if [ "$DOXYGEN" = yes ]; then apt-get install doxygen; fi
90 - if [ "$STEM" = yes ]; then apt-get install timelimit; fi
91 - if [ "$CC" = clang ]; then apt-get install clang; fi
92 - if [ "$NSS" = yes ]; then apt-get install libnss3 libnss3-dev; fi
93 # TODO: This next line should not be debian-only.
94 - if [ "$STEM" = yes ]; then git clone --depth 1 https://git.torproject.org/stem.git ; export STEM_PATH="$(pwd)/stem"; fi
95 # TODO: This next line should not be debian-only.
96 - if [ "$CHUTNEY" = yes ]; then git clone --depth 1 https://git.torproject.org/chutney.git ; export CHUTNEY_PATH="$(pwd)/chutney"; fi
97 - if [ "$TRACING" = yes ]; then apt install liblttng-ust-dev; fi
99 # Minimal check on debian: just make, make check.
105 - ./scripts/ci/ci-driver.sh
108 # Run "make check" with a hardened clang on debian stable. This takes
109 # care of a hardening check, and a compile-with-clang check.
111 # TODO: This will be faster once we merge #40098 and #40099.
113 image: debian:testing
116 ALL_BUGS_ARE_FATAL: "yes"
120 - ./scripts/ci/ci-driver.sh
123 # Distcheck on debian stable
131 - ./scripts/ci/ci-driver.sh
134 # Documentation tests on debian stable: doxygen and asciidoc.
142 RUN_STAGE_BUILD: "no"
144 - ./scripts/ci/ci-driver.sh
147 # Integration tests on debian stable: chutney and stem.
149 # TODO: It would be cool if this target didn't have to re-build tor, and
150 # could instead re-use Tor from debian-minimal. That can be done
151 # with the 'artifacts' mechanism, in theory, but it would be good to
152 # avoid having to have a system with hundreds of artifacts.
159 CHUTNEY_MAKE_TARGET: "test-network-all"
161 ALL_BUGS_ARE_FATAL: "yes"
163 - ./scripts/ci/ci-driver.sh
166 # Tracing build on Debian stable.
175 - ./scripts/ci/ci-driver.sh
176 # Ensure that we only run tracing when it's implemented.
178 # Once versions before 0.4.5 are obsolete, we can remove this test.
180 # This first "if" check prevents us from running a duplicate version of
181 # this pipeline whenever we push and create an MR. I don't understand why
182 # it is necessary, though the following URL purports to explain:
184 # https://docs.gitlab.com/ee/ci/yaml/#prevent-duplicate-pipelines
185 - if: '$CI_PIPELINE_SOURCE == "push"'
187 - src/lib/trace/trace_sys.c
191 debian-disable-dirauth:
195 DISABLE_DIRAUTH: "yes"
197 - ./scripts/ci/ci-driver.sh
201 debian-disable-relay:
207 - ./scripts/ci/ci-driver.sh
208 # Ensure that we only run tracing when it's implemented.
210 # Once versions before 0.4.3 are obsolete, we can remove this test.
212 # This first "if" check prevents us from running a duplicate version of
213 # this pipeline whenever we push and create an MR. I don't understand why
214 # it is necessary, though the following URL purports to explain:
216 # https://docs.gitlab.com/ee/ci/yaml/#prevent-duplicate-pipelines
217 - if: '$CI_PIPELINE_SOURCE == "push"'
219 - src/feature/relay/relay_stub.c
222 # NSS check on debian
229 - ./scripts/ci/ci-driver.sh