feat: add go lint
This commit is contained in:
@@ -0,0 +1,4 @@
|
||||
include:
|
||||
- /.gitlab-ci-default-runners.yml
|
||||
|
||||
# Currently we're happy with the defaults
|
||||
+12
@@ -0,0 +1,12 @@
|
||||
# This is just used for the scheduled pipelines in the
|
||||
# https://gitlab.com/samba-team/samba configuration
|
||||
#
|
||||
|
||||
variables:
|
||||
SAMBA_CI_FLAVOR: "coverage"
|
||||
# "--enable-coverage" or ""
|
||||
SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE: "--enable-coverage"
|
||||
|
||||
include:
|
||||
- /.gitlab-ci-coverage-runners.yml
|
||||
- /.gitlab-ci-main.yml
|
||||
+30
@@ -0,0 +1,30 @@
|
||||
# From https://docs.gitlab.com/ee/ci/runners/hosted_runners/linux.html
|
||||
#
|
||||
# ...
|
||||
#
|
||||
# Runner Tag vCPUs Memory Storage
|
||||
# saas-linux-small-amd64 2 8 GB 25 GB
|
||||
#
|
||||
# Our current private runner 'docker', 'samba-ci-private', 'shared' and
|
||||
# 'ubuntu2204'. It runs with an ubuntu2204 kernel (5.15) and provides an
|
||||
# ext4 filesystem, 2 CPU and 4 GB (shared tag) 8G (samba-ci-private tag) RAM.
|
||||
#
|
||||
|
||||
.shared_runner_build:
|
||||
# We use saas-linux-small-amd64 shared runners by default.
|
||||
# We avoid adding explicit tags for them in order
|
||||
# to work with potential changes in future
|
||||
#
|
||||
# In order to generate valid yaml, we define a dummy variable...
|
||||
variables:
|
||||
SAMBA_SHARED_RUNNER_BUILD_DUMMY_VARIABLE: shared_runner_build
|
||||
|
||||
.shared_runner_test:
|
||||
# We use saas-linux-small-amd64 shared runners by default.
|
||||
extends: .shared_runner_build
|
||||
|
||||
.private_runner_test:
|
||||
# We use our private runner only for special tests
|
||||
tags:
|
||||
- docker
|
||||
- samba-ci-private
|
||||
+10
@@ -0,0 +1,10 @@
|
||||
variables:
|
||||
SAMBA_CI_FLAVOR: "default"
|
||||
# "--enable-coverage" or ""
|
||||
# See .gitlab-ci-coverage.yml
|
||||
SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE: ""
|
||||
AUTOBUILD_SKIP_SAMBA_O3: "0"
|
||||
|
||||
include:
|
||||
- /.gitlab-ci-default-runners.yml
|
||||
- /.gitlab-ci-main.yml
|
||||
Vendored
+688
@@ -0,0 +1,688 @@
|
||||
# see https://docs.gitlab.com/ce/ci/yaml/README.html for all available options
|
||||
|
||||
# Stages explained
|
||||
#
|
||||
# images: Build the images with the bootstrap script
|
||||
# build_first: Build a few things first to find silly errors (fast job)
|
||||
# (don't pay for 35 machines until something compiles)
|
||||
# build: The main parallel job
|
||||
# (keep these to 1hour as we are billed per hour)
|
||||
# test_only: Tests using the build from prior stages, these typically
|
||||
# have an explicit dependency defined to a specific build job,
|
||||
# which means that start as soon as the build job finished.
|
||||
# test_private: Like test_only, but running on private runners
|
||||
# report: Code coverage reporting
|
||||
|
||||
stages:
|
||||
- images
|
||||
- build_first
|
||||
- build
|
||||
- test_only
|
||||
- test_private
|
||||
- report
|
||||
|
||||
variables:
|
||||
# We want to be resilient to runner failures
|
||||
ARTIFACT_DOWNLOAD_ATTEMPTS: "3"
|
||||
EXECUTOR_JOB_SECTION_ATTEMPTS: "3"
|
||||
GET_SOURCES_ATTEMPTS: "3"
|
||||
RESTORE_CACHE_ATTEMPTS: "3"
|
||||
#
|
||||
GIT_STRATEGY: fetch
|
||||
GIT_DEPTH: "3"
|
||||
#
|
||||
# Use GZip by default, it is fast and is good enough. Other options include --xz
|
||||
|
||||
SAMBA_TESTBASE_TAR_OPTIONS: -z
|
||||
|
||||
#
|
||||
# we run autobuild.py inside a samba CI docker image located on gitlab's registry
|
||||
# overwrite this variable if you want use your own image registry.
|
||||
#
|
||||
# Or better ask for access to the shared development repository, see
|
||||
# https://wiki.samba.org/index.php/Samba_CI_on_gitlab#Getting_Access
|
||||
#
|
||||
SAMBA_CI_CONTAINER_REGISTRY: registry.gitlab.com/samba-team/devel/samba
|
||||
#
|
||||
# Set this to the contents of bootstrap/sha1sum.txt
|
||||
# which is generated by bootstrap/template.py --render
|
||||
#
|
||||
SAMBA_CI_CONTAINER_TAG: e494a8092a6d0e794223f56ddb2ffbaf76402cf6
|
||||
#
|
||||
# We use the ubuntu2204 image as default as
|
||||
# it matches what we have on atb-devel-224
|
||||
#
|
||||
SAMBA_CI_CONTAINER_IMAGE: ubuntu2204
|
||||
#
|
||||
# The following images are available
|
||||
# Please see the samba-o3 sections at the end of this file!
|
||||
# We should run that for each available image
|
||||
#
|
||||
SAMBA_CI_CONTAINER_IMAGE_ubuntu2204: ubuntu2204
|
||||
SAMBA_CI_CONTAINER_IMAGE_ubuntu2404: ubuntu2404
|
||||
SAMBA_CI_CONTAINER_IMAGE_ubuntu2604: ubuntu2604
|
||||
SAMBA_CI_CONTAINER_IMAGE_debian11: debian11
|
||||
SAMBA_CI_CONTAINER_IMAGE_debian11_32bit: debian11-32bit
|
||||
SAMBA_CI_CONTAINER_IMAGE_debian12: debian12
|
||||
SAMBA_CI_CONTAINER_IMAGE_opensuse160: opensuse160
|
||||
SAMBA_CI_CONTAINER_IMAGE_rocky8: rocky8
|
||||
SAMBA_CI_CONTAINER_IMAGE_centos9s: centos9s
|
||||
SAMBA_CI_CONTAINER_IMAGE_fedora43: fedora43
|
||||
|
||||
include:
|
||||
# The image creation details are specified in a separate file
|
||||
# See bootstrap/README.md for details
|
||||
- 'bootstrap/.gitlab-ci.yml'
|
||||
|
||||
.shared_runner_build_image:
|
||||
extends: .shared_runner_build
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE}
|
||||
image: ${SAMBA_CI_CONTAINER_REGISTRY}/samba-ci-${SAMBA_CI_JOB_IMAGE}:${SAMBA_CI_CONTAINER_TAG}
|
||||
|
||||
.shared_template:
|
||||
extends: .shared_runner_build_image
|
||||
# All Samba jobs are interruptible, this avoids burning CPU when a
|
||||
# newer branch is pushed.
|
||||
interruptible: true
|
||||
timeout: 2h
|
||||
|
||||
# Otherwise we run twice, once on push and once on MR
|
||||
# https://forum.gitlab.com/t/new-rules-syntax-and-detached-pipelines/37292
|
||||
rules:
|
||||
- if: $CI_MERGE_REQUEST_ID
|
||||
when: never
|
||||
- when: on_success
|
||||
|
||||
variables:
|
||||
AUTOBUILD_JOB_NAME: $CI_JOB_NAME
|
||||
stage: build
|
||||
cache:
|
||||
key: ccache.${CI_JOB_NAME}.${SAMBA_CI_JOB_IMAGE}.${SAMBA_CI_FLAVOR}
|
||||
paths:
|
||||
- ccache
|
||||
|
||||
# This is overridden in many cases, but ensures none of the other
|
||||
# main jobs start until and unless this build finishes. However
|
||||
# this also ensures we do not download artifacts from any build
|
||||
# unless we specifically depend on it, saving bandwidth
|
||||
|
||||
needs:
|
||||
- job: samba-def-build
|
||||
artifacts: false
|
||||
|
||||
before_script:
|
||||
- uname -a
|
||||
- ls -l /sys/module/
|
||||
- ls -l /sys/kernel/security/
|
||||
- if [ -e /sys/kernel/security/lsm ]; then cat /sys/kernel/security/lsm ; echo; fi
|
||||
- if [ -e /proc/config.gz ]; then sudo zcat /proc/config.gz; echo; fi
|
||||
- lsb_release -a
|
||||
- cat /etc/os-release
|
||||
- id
|
||||
- cat /proc/self/status
|
||||
- lscpu
|
||||
- cat /proc/cpuinfo
|
||||
- mount
|
||||
- df -h
|
||||
- cat /proc/swaps
|
||||
- free -h
|
||||
# ld will fail if coverage enabled, force link ld to ld.bfd
|
||||
- if [ -n "$SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE" ]; then sudo ln -sf $(which ld.bfd) $(which ld); fi
|
||||
# See bootstrap/.gitlab-ci.yml how to generate a new image
|
||||
- echo "SAMBA_CI_CONTAINER_REGISTRY[${SAMBA_CI_CONTAINER_REGISTRY}]"
|
||||
- echo "SAMBA_CI_CONTAINER_TAG[${SAMBA_CI_CONTAINER_TAG}]"
|
||||
- echo "SAMBA_CI_JOB_IMAGE[${SAMBA_CI_JOB_IMAGE}]"
|
||||
- echo "CI_JOB_IMAGE[${CI_JOB_IMAGE}]"
|
||||
- bootstrap/template.py --sha1sum > /tmp/sha1sum-template.txt
|
||||
- diff -u bootstrap/sha1sum.txt /tmp/sha1sum-template.txt
|
||||
- echo "${SAMBA_CI_CONTAINER_TAG}" > /tmp/sha1sum-tag.txt
|
||||
- diff -u bootstrap/sha1sum.txt /tmp/sha1sum-tag.txt
|
||||
- diff -u bootstrap/sha1sum.txt /sha1sum.txt
|
||||
- echo "${CI_COMMIT_SHA} ${CI_COMMIT_TITLE}" > /tmp/commit.txt
|
||||
- export CCACHE_BASEDIR="${PWD}"
|
||||
- export CCACHE_DIR="${PWD}/ccache" && mkdir -pv "$CCACHE_DIR"
|
||||
- export CC="ccache cc"
|
||||
- export CXX="ccache c++"
|
||||
- ccache -z -M 500M
|
||||
- ccache -s
|
||||
# We are already running .gitlab-ci directives from this repo, remove additional checks that break our CI
|
||||
- git config --global --add safe.directory '*'
|
||||
after_script:
|
||||
- mount
|
||||
- df -h
|
||||
- cat /proc/swaps
|
||||
- free -h
|
||||
- CCACHE_BASEDIR="${PWD}" CCACHE_DIR="${PWD}/ccache" ccache -s -c
|
||||
artifacts:
|
||||
expire_in: 1 week
|
||||
paths:
|
||||
- "*.stdout"
|
||||
- "*.stderr"
|
||||
- "*.info"
|
||||
- public
|
||||
- system-info.txt
|
||||
retry:
|
||||
max: 2
|
||||
when:
|
||||
- runner_system_failure
|
||||
- stuck_or_timeout_failure
|
||||
- api_failure
|
||||
- runner_unsupported
|
||||
- stale_schedule
|
||||
- archived_failure
|
||||
- scheduler_failure
|
||||
- data_integrity_failure
|
||||
|
||||
script:
|
||||
# gitlab predefines CI_JOB_NAME for each job. The gitlab job usually matches the
|
||||
# autobuild name, which means we can define a default template that runs most autobuild jobs
|
||||
- script/autobuild.py $AUTOBUILD_JOB_NAME $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase
|
||||
|
||||
# Ensure when adding a new job below that you also add it to
|
||||
# the dependencies for 'pages' below for the code coverage page
|
||||
# generation.
|
||||
|
||||
others:
|
||||
extends: .shared_template
|
||||
script:
|
||||
- script/autobuild.py pidl $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/pidl
|
||||
- script/autobuild.py replace $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/replace
|
||||
- script/autobuild.py talloc $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/talloc
|
||||
- script/autobuild.py tdb $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/tdb
|
||||
- script/autobuild.py tevent $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/tevent
|
||||
- script/autobuild.py samba-xc $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/samba-xc
|
||||
- script/autobuild.py docs-xml $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase/docs-xml
|
||||
- make -C coverity
|
||||
|
||||
.shared_template_build_only:
|
||||
extends: .shared_template
|
||||
timeout: 2h
|
||||
needs:
|
||||
artifacts:
|
||||
expire_in: 1 week
|
||||
paths:
|
||||
- "*.stdout"
|
||||
- "*.stderr"
|
||||
- "*.info"
|
||||
- system-info.txt
|
||||
- samba-testbase.tar
|
||||
script:
|
||||
# gitlab predefines CI_JOB_NAME for each job. The gitlab job usually matches the
|
||||
# autobuild name, which means we can define a default template that runs most autobuild jobs
|
||||
- script/autobuild.py $AUTOBUILD_JOB_NAME $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase
|
||||
# On success we need to pack everything into an artifacts file
|
||||
# which needs to be in the git checkout.
|
||||
# As tar doesn't handle hardlink of read-only files,
|
||||
# we remember the acls and add write permissions
|
||||
# before creating the archive. The consumer will apply
|
||||
# the acls again.
|
||||
- cp -a /sha1sum.txt /builds/samba-testbase/image-sha1sum.txt
|
||||
- cp -a /tmp/commit.txt /builds/samba-testbase/commit.txt
|
||||
- ln -s /builds/samba-testbase/${AUTOBUILD_JOB_NAME}/ /builds/samba-testbase/build_subdir_link
|
||||
- pushd /builds && getfacl -R samba-testbase > samba-testbase.acl.dump && popd
|
||||
- chmod -R +w /builds/samba-testbase
|
||||
- mv /builds/samba-testbase.acl.dump /builds/samba-testbase/
|
||||
- tar $SAMBA_TESTBASE_TAR_OPTIONS -cf samba-testbase.tar /builds/samba-testbase
|
||||
- ls -la samba-testbase.tar
|
||||
- sha1sum samba-testbase.tar
|
||||
|
||||
.shared_template_test_only:
|
||||
extends:
|
||||
- .shared_template
|
||||
- .shared_runner_test
|
||||
stage: test_only
|
||||
script:
|
||||
# Print the Kerberos version to check we ended up with the right one
|
||||
# in the runner. We do not have configure output to recognize it
|
||||
# otherwise.
|
||||
- if [ -x "$(command -v krb5-config)" ]; then krb5-config --version; fi
|
||||
# We unpack the artifacts file created by the .shared_template_build_only
|
||||
# run we depend on
|
||||
- ls -la samba-testbase.tar
|
||||
- sha1sum samba-testbase.tar
|
||||
- tar $SAMBA_TESTBASE_TAR_OPTIONS -xf samba-testbase.tar -C /
|
||||
- diff -u /builds/samba-testbase/image-sha1sum.txt /sha1sum.txt
|
||||
- diff -u /builds/samba-testbase/commit.txt /tmp/commit.txt
|
||||
- mv /builds/samba-testbase/samba-testbase.acl.dump /builds/samba-testbase.acl.dump
|
||||
- pushd /builds && setfacl --restore=/builds/samba-testbase.acl.dump && popd
|
||||
- ls -la /builds/samba-testbase/
|
||||
- ls -la /builds/samba-testbase/build_subdir_link
|
||||
- ls -la /builds/samba-testbase/build_subdir_link/
|
||||
- if [ -n "$SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE" ]; then find /builds/samba-testbase/build_subdir_link/ -type d -printf "'%p'\n" | xargs chmod u+w; fi
|
||||
- ls -la /builds/samba-testbase/build_subdir_link/
|
||||
# gitlab predefines CI_JOB_NAME for each job. The gitlab job usually matches the
|
||||
# autobuild name, which means we can define a default template that runs most autobuild jobs
|
||||
- script/autobuild.py $AUTOBUILD_JOB_NAME $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE --skip-dependencies --verbose --nocleanup --keeplogs --tail --full-testbase /builds/samba-testbase
|
||||
|
||||
samba-def-build:
|
||||
extends: .shared_template_build_only
|
||||
stage: build_first
|
||||
|
||||
.needs_samba-def-build:
|
||||
extends: .shared_template_test_only
|
||||
needs:
|
||||
- job: samba-def-build
|
||||
artifacts: true
|
||||
- job: samba-codecheck
|
||||
|
||||
samba-mit-build:
|
||||
extends: .shared_template_build_only
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_fedora43}
|
||||
stage: build_first
|
||||
|
||||
.needs_samba-mit-build:
|
||||
extends: .shared_template_test_only
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_fedora43}
|
||||
needs:
|
||||
- job: samba-mit-build
|
||||
artifacts: true
|
||||
- job: samba-codecheck
|
||||
|
||||
samba-h5l-build:
|
||||
extends: .shared_template_build_only
|
||||
|
||||
.needs_samba-h5l-build:
|
||||
extends: .shared_template_test_only
|
||||
needs:
|
||||
- job: samba-h5l-build
|
||||
artifacts: true
|
||||
|
||||
samba-without-smb1-build:
|
||||
extends: .shared_template_build_only
|
||||
|
||||
.needs_samba-without-smb1-build:
|
||||
extends: .shared_template_test_only
|
||||
needs:
|
||||
- job: samba-without-smb1-build
|
||||
artifacts: true
|
||||
|
||||
samba-nt4-build:
|
||||
extends: .shared_template_build_only
|
||||
|
||||
.needs_samba-nt4-build:
|
||||
extends: .shared_template_test_only
|
||||
needs:
|
||||
- job: samba-nt4-build
|
||||
artifacts: true
|
||||
|
||||
samba-no-opath-build:
|
||||
extends: .shared_template_build_only
|
||||
|
||||
.needs_samba-no-opath-build:
|
||||
extends: .shared_template_test_only
|
||||
needs:
|
||||
- job: samba-no-opath-build
|
||||
artifacts: true
|
||||
|
||||
samba:
|
||||
extends: .shared_template
|
||||
|
||||
samba-mitkrb5:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_fedora43}
|
||||
|
||||
samba-minimal-smbd:
|
||||
extends: .shared_template
|
||||
|
||||
samba-nopython:
|
||||
extends: .shared_template
|
||||
|
||||
samba-admem:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-2:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-3:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-4a:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-4b:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-5:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-dc-6:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-back1:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-ad-back2:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-schemaupgrade:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-libs:
|
||||
extends: .shared_template
|
||||
|
||||
samba-fuzz:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_ubuntu2404}
|
||||
|
||||
ctdb:
|
||||
extends: .shared_template
|
||||
|
||||
samba-ctdb:
|
||||
extends: .shared_template
|
||||
|
||||
samba-ad-dc-ntvfs:
|
||||
extends: .needs_samba-def-build
|
||||
|
||||
samba-admem-mit:
|
||||
extends: .needs_samba-mit-build
|
||||
|
||||
samba-addc-mit-4a:
|
||||
extends: .needs_samba-mit-build
|
||||
|
||||
samba-addc-mit-4b:
|
||||
extends: .needs_samba-mit-build
|
||||
|
||||
# This task is run first to ensure we compile before we start the
|
||||
# main run as it is the fastest full compile of Samba.
|
||||
samba-fips:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_fedora43}
|
||||
|
||||
samba-codecheck:
|
||||
extends: .shared_template
|
||||
needs:
|
||||
stage: build_first
|
||||
|
||||
.private_test_only:
|
||||
extends: .private_runner_test
|
||||
stage: test_private
|
||||
rules:
|
||||
# See above, to avoid a duplicate CI on the MR (these rules override the others)
|
||||
- if: $CI_MERGE_REQUEST_ID
|
||||
when: never
|
||||
|
||||
# These jobs are only run if the gitlab repo has private runners available.
|
||||
# To enable private jobs, you must add the following var and value to
|
||||
# your gitlab repo by navigating to:
|
||||
# settings -> CI/CD -> Environment variables
|
||||
- if: $SUPPORT_PRIVATE_TEST == "yes"
|
||||
|
||||
.needs_ext4_support:
|
||||
# All runners provide an ext4 filesystem
|
||||
#
|
||||
# Note: we don't use
|
||||
# extends: .shared_template_test_only
|
||||
# as that somehow resets the needs section
|
||||
# and generates problems for something
|
||||
# like this (which is used below)
|
||||
#
|
||||
# .needs_samba-SOME-build-ext4:
|
||||
# extends:
|
||||
# - .needs_samba-SOME-build
|
||||
# - .needs_ext4_support
|
||||
#
|
||||
# So we only set stage again instead...
|
||||
stage: test_only
|
||||
|
||||
.needs_5_15_kernel:
|
||||
# Our private runners are based on
|
||||
# ubuntu2204 with a 5.15 kernel.
|
||||
#
|
||||
# And they also provide an ext4 filesystem
|
||||
extends: .private_test_only
|
||||
|
||||
.needs_samba-def-build-ext4:
|
||||
extends:
|
||||
- .needs_samba-def-build
|
||||
- .needs_ext4_support
|
||||
|
||||
.needs_samba-mit-build-ext4:
|
||||
extends:
|
||||
- .needs_samba-mit-build
|
||||
- .needs_ext4_support
|
||||
|
||||
.needs_samba-h5l-build-ext4:
|
||||
extends:
|
||||
- .needs_samba-h5l-build
|
||||
- .needs_ext4_support
|
||||
|
||||
.needs_samba-without-smb1-build-5_15:
|
||||
# Currently this doesn't strictly
|
||||
# require a kernel >= 5.15, but only
|
||||
# ext4 support.
|
||||
#
|
||||
# But we want to make sure that
|
||||
# our private runners keep working
|
||||
# and at least do a single job.
|
||||
#
|
||||
# In future we'll be able to run
|
||||
# tests with io_uring in this
|
||||
# setup, which will requires a
|
||||
# 5.15 kernel in order to be useful.
|
||||
extends:
|
||||
- .needs_samba-without-smb1-build
|
||||
- .needs_5_15_kernel
|
||||
|
||||
.needs_samba-nt4-build-ext4:
|
||||
extends:
|
||||
- .needs_samba-nt4-build
|
||||
- .needs_ext4_support
|
||||
|
||||
.needs_samba-no-opath-build-ext4:
|
||||
extends:
|
||||
- .needs_samba-no-opath-build
|
||||
- .needs_ext4_support
|
||||
|
||||
samba-fileserver:
|
||||
extends: .needs_samba-h5l-build-ext4
|
||||
|
||||
samba-fileserver-without-smb1:
|
||||
extends: .needs_samba-without-smb1-build
|
||||
|
||||
# This is a full build without the AD DC so we test the build with MIT
|
||||
# Kerberos from the default system (Ubuntu 22.04 at this stage).
|
||||
# Runtime behaviour checked via the ktest (static ccache and keytab)
|
||||
# environment
|
||||
samba-ktest-mit:
|
||||
extends: .shared_template
|
||||
|
||||
samba-ad-dc-1:
|
||||
extends: .needs_samba-def-build-ext4
|
||||
|
||||
samba-nt4:
|
||||
extends: .needs_samba-nt4-build-ext4
|
||||
|
||||
samba-addc-mit-1:
|
||||
extends: .needs_samba-mit-build-ext4
|
||||
|
||||
samba-no-opath1:
|
||||
extends: .needs_samba-no-opath-build-ext4
|
||||
|
||||
samba-no-opath2:
|
||||
extends: .needs_samba-no-opath-build-ext4
|
||||
|
||||
# 'pages' is a special job which can publish artifacts in `public` dir to gitlab pages
|
||||
pages:
|
||||
extends: .shared_runner_build_image
|
||||
stage: report
|
||||
dependencies: # tell gitlab to download artifacts for these jobs
|
||||
- others
|
||||
- samba
|
||||
- samba-mitkrb5
|
||||
- samba-admem
|
||||
- samba-ad-dc-2
|
||||
- samba-ad-dc-3
|
||||
- samba-ad-dc-4a
|
||||
- samba-ad-dc-4b
|
||||
- samba-ad-dc-5
|
||||
- samba-ad-dc-6
|
||||
- samba-libs
|
||||
- samba-minimal-smbd
|
||||
- samba-nopython
|
||||
- samba-fuzz
|
||||
# - ctdb # TODO
|
||||
- samba-ctdb
|
||||
- samba-ad-dc-ntvfs
|
||||
- samba-admem-mit
|
||||
- samba-addc-mit-4a
|
||||
- samba-addc-mit-4b
|
||||
- samba-ad-back1
|
||||
- samba-ad-back2
|
||||
- samba-fileserver
|
||||
- samba-fileserver-without-smb1
|
||||
- samba-ad-dc-1
|
||||
- samba-nt4
|
||||
- samba-schemaupgrade
|
||||
- samba-addc-mit-1
|
||||
- samba-fips
|
||||
- samba-no-opath1
|
||||
- samba-no-opath2
|
||||
- ubuntu2204-samba-o3
|
||||
script:
|
||||
- ls -la *.info
|
||||
- ./configure.developer
|
||||
- make -j
|
||||
- ls -la *.info
|
||||
- lcov $(ls *.info | xargs -I{} echo -n "-a {} ") -o all.info
|
||||
- ls -la *.info
|
||||
- genhtml all.info --ignore-errors source --output-directory public --prefix=$(pwd) --title "coverage report for $CI_COMMIT_REF_NAME $CI_COMMIT_SHORT_SHA"
|
||||
artifacts:
|
||||
expire_in: 30 days
|
||||
paths:
|
||||
- public
|
||||
only:
|
||||
variables:
|
||||
- $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE == "--enable-coverage"
|
||||
|
||||
# Coverity Scan
|
||||
coverity:
|
||||
extends: .shared_runner_build_image
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_opensuse160}
|
||||
stage: build
|
||||
script:
|
||||
- wget https://scan.coverity.com/download/linux64 --post-data "token=$COVERITY_SCAN_TOKEN&project=$COVERITY_SCAN_PROJECT_NAME" -O /tmp/coverity_tool.tgz
|
||||
- tar xf /tmp/coverity_tool.tgz
|
||||
- ./configure.developer --with-cluster-support
|
||||
- cov-analysis-linux64-*/bin/coverity capture --dir cov-int --project-dir ./
|
||||
- tar czf cov-int.tar.gz cov-int
|
||||
- curl
|
||||
--form token=$COVERITY_SCAN_TOKEN
|
||||
--form email=$COVERITY_SCAN_EMAIL
|
||||
--form file=@cov-int.tar.gz
|
||||
--form version="`git describe --tags`"
|
||||
--form description="CI build"
|
||||
https://scan.coverity.com/builds?project=$COVERITY_SCAN_PROJECT_NAME
|
||||
only:
|
||||
refs:
|
||||
- master
|
||||
- schedules
|
||||
variables:
|
||||
- $COVERITY_SCAN_TOKEN != null
|
||||
- $COVERITY_SCAN_PROJECT_NAME != null
|
||||
- $COVERITY_SCAN_EMAIL != null
|
||||
artifacts:
|
||||
expire_in: 1 week
|
||||
when: on_failure
|
||||
paths:
|
||||
- cov-int/*.txt
|
||||
|
||||
debian11-samba-32bit:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
AUTOBUILD_JOB_NAME: samba-32bit
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_debian11_32bit}
|
||||
|
||||
#
|
||||
# We build samba-o3 on all supported distributions
|
||||
#
|
||||
|
||||
# This job, which matches the main CI, needs to still do coverage so
|
||||
# we show the coverage on the "none" environment tests
|
||||
#
|
||||
# We want --enable-coverage specified here otherwise we will have a
|
||||
# different set of build options on the coverage build and can fail
|
||||
# when -O3 gets combined with --enable-coverage in the scheduled
|
||||
# builds.
|
||||
|
||||
ubuntu2204-samba-o3:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
AUTOBUILD_JOB_NAME: samba-o3
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_ubuntu2204}
|
||||
SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE: "--enable-coverage"
|
||||
rules:
|
||||
# See above, to avoid a duplicate CI on the MR (these rules override the others)
|
||||
- if: $CI_MERGE_REQUEST_ID
|
||||
when: never
|
||||
# do not run o3 builds (which run a lot of VMs) if told not to
|
||||
# (this uses the same variable as autobuild.py)
|
||||
- if: $AUTOBUILD_SKIP_SAMBA_O3 == "1"
|
||||
when: never
|
||||
- when: on_success
|
||||
|
||||
# All other jobs do not want code coverage.
|
||||
.samba-o3-template:
|
||||
extends: .shared_template
|
||||
variables:
|
||||
AUTOBUILD_JOB_NAME: samba-o3
|
||||
rules:
|
||||
# See above, to avoid a duplicate CI on the MR (these rules override the others)
|
||||
- if: $CI_MERGE_REQUEST_ID
|
||||
when: never
|
||||
# do not run o3 builds (which run a lot of VMs) if told not to
|
||||
# (this uses the same variable as autobuild.py)
|
||||
- if: $AUTOBUILD_SKIP_SAMBA_O3 == "1"
|
||||
when: never
|
||||
# do not run o3 for coverage since they are using different images
|
||||
- if: $SAMBA_CI_AUTOBUILD_ENABLE_COVERAGE == ""
|
||||
|
||||
ubuntu2404-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_ubuntu2404}
|
||||
|
||||
ubuntu2604-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_ubuntu2604}
|
||||
|
||||
debian11-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_debian11}
|
||||
|
||||
debian12-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_debian12}
|
||||
|
||||
opensuse160-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_opensuse160}
|
||||
|
||||
rocky8-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_rocky8}
|
||||
|
||||
centos9s-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_centos9s}
|
||||
|
||||
fedora43-samba-o3:
|
||||
extends: .samba-o3-template
|
||||
variables:
|
||||
SAMBA_CI_JOB_IMAGE: ${SAMBA_CI_CONTAINER_IMAGE_fedora43}
|
||||
|
||||
#
|
||||
# Keep the samba-o3 sections at the end ...
|
||||
#
|
||||
+5
@@ -0,0 +1,5 @@
|
||||
# This is just a legacy alias used by the
|
||||
# https://gitlab.com/samba-team/devel/samba configuration
|
||||
#
|
||||
include:
|
||||
- '/.gitlab-ci.yml'
|
||||
Vendored
+2
@@ -0,0 +1,2 @@
|
||||
include:
|
||||
- /.gitlab-ci-default.yml
|
||||
Vendored
+16
@@ -0,0 +1,16 @@
|
||||
#
|
||||
# GitLeaks Repo Specific Configuration
|
||||
#
|
||||
# This allowlist is used to help Red Hat ignore false positives during its code
|
||||
# scans.
|
||||
|
||||
[allowlist]
|
||||
paths = [
|
||||
'''docs-xml/manpages/smbstatus.1.xml''',
|
||||
'''selftests/*''',
|
||||
'''source3/script/tests/*''',
|
||||
'''source4/dsdb/tests/*''',
|
||||
'''source4/torture/*''',
|
||||
'''testprogs/blackbox/*''',
|
||||
'''tests/*''',
|
||||
]
|
||||
+122
@@ -0,0 +1,122 @@
|
||||
---
|
||||
.build_image_template:
|
||||
image: quay.io/podman/stable:latest
|
||||
stage: images
|
||||
tags:
|
||||
# We need to make sure we only use gitlab.com
|
||||
# runners and not our own runners, as our current runners
|
||||
# don't allow 'docker build ...' to run.
|
||||
- saas-linux-small-amd64
|
||||
variables:
|
||||
SAMBA_CI_IS_BROKEN_IMAGE: "no"
|
||||
SAMBA_CI_TEST_JOB: "samba-o3"
|
||||
SAMBA_CI_PLATFORM: "linux/amd64"
|
||||
before_script:
|
||||
# install prerequisites
|
||||
- dnf install -qy diffutils
|
||||
# Ensure we are generating correct the container
|
||||
- uname -a
|
||||
- cat /etc/os-release
|
||||
- echo "SAMBA_CI_CONTAINER_REGISTRY[${SAMBA_CI_CONTAINER_REGISTRY}]"
|
||||
- echo "SAMBA_CI_CONTAINER_TAG[${SAMBA_CI_CONTAINER_TAG}]"
|
||||
- echo "SAMBA_CI_IS_BROKEN_IMAGE[${SAMBA_CI_IS_BROKEN_IMAGE}]"
|
||||
- echo "SAMBA_CI_REBUILD_IMAGES[${SAMBA_CI_REBUILD_IMAGES}]"
|
||||
- echo "SAMBA_CI_REBUILD_BROKEN_IMAGES[${SAMBA_CI_REBUILD_BROKEN_IMAGES}]"
|
||||
- echo "GITLAB_USER_LOGIN[${GITLAB_USER_LOGIN}]"
|
||||
- echo "${SAMBA_CI_CONTAINER_TAG}" > /tmp/sha1sum-tag.txt
|
||||
- diff -u bootstrap/sha1sum.txt /tmp/sha1sum-tag.txt
|
||||
script: |
|
||||
set -xueo pipefail
|
||||
ci_image_name=samba-ci-${CI_JOB_NAME}
|
||||
podman build --platform ${SAMBA_CI_PLATFORM} --tag ${ci_image_name} --build-arg SHA1SUM=${SAMBA_CI_CONTAINER_TAG} bootstrap/generated-dists/${CI_JOB_NAME}
|
||||
ci_image_path="${SAMBA_CI_CONTAINER_REGISTRY}/${ci_image_name}"
|
||||
timestamp=$(date +%Y%m%d%H%M%S)
|
||||
container_hash=$(podman image inspect --format='{{ .Id }}' ${ci_image_name} | cut -c 1-9)
|
||||
timestamp_tag=${SAMBA_CI_CONTAINER_TAG}-${timestamp}-${GITLAB_USER_LOGIN}-${container_hash}
|
||||
samba_repo_root=/home/samba/samba
|
||||
# Ensure we are generating the correct container that we expect to be in
|
||||
echo "${SAMBA_CI_CONTAINER_TAG}" > /tmp/sha1sum-tag.txt
|
||||
diff -u bootstrap/sha1sum.txt /tmp/sha1sum-tag.txt
|
||||
podman run --volume $(pwd):${samba_repo_root} --workdir ${samba_repo_root} ${ci_image_name} \
|
||||
/bin/bash -c "echo \"${SAMBA_CI_CONTAINER_TAG}\" > /tmp/sha1sum-tag.txt; diff -u bootstrap/sha1sum.txt /tmp/sha1sum-tag.txt"
|
||||
podman run --volume $(pwd):${samba_repo_root} --workdir ${samba_repo_root} ${ci_image_name} \
|
||||
diff -u bootstrap/sha1sum.txt /sha1sum.txt
|
||||
podman run --volume $(pwd):${samba_repo_root} --workdir ${samba_repo_root} ${ci_image_name} \
|
||||
bootstrap/template.py --sha1sum > /tmp/sha1sum-template.txt
|
||||
diff -u bootstrap/sha1sum.txt /tmp/sha1sum-template.txt
|
||||
# run smoke test with samba-o3 or samba-fuzz
|
||||
podman run --volume $(pwd):/src:ro ${ci_image_name} \
|
||||
/bin/bash -c "git config --global --add safe.directory /src/.git && git clone /src samba && cd samba && export PKG_CONFIG_PATH=/usr/lib64/compat-gnutls34/pkgconfig:/usr/lib64/compat-nettle32/pkgconfig && script/autobuild.py ${SAMBA_CI_TEST_JOB} --verbose --nocleanup --keeplogs --tail --testbase /tmp/samba-testbase"
|
||||
podman tag ${ci_image_name} ${ci_image_path}:${SAMBA_CI_CONTAINER_TAG}
|
||||
podman tag ${ci_image_name} ${ci_image_path}:${timestamp_tag}
|
||||
# We build all images, but only upload is it's not marked as broken
|
||||
test x"${SAMBA_CI_IS_BROKEN_IMAGE}" = x"yes" || { \
|
||||
podman login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY; \
|
||||
podman push ${ci_image_path}:${SAMBA_CI_CONTAINER_TAG}; \
|
||||
podman push ${ci_image_path}:${timestamp_tag}; \
|
||||
}
|
||||
echo "Success for ${ci_image_path}:${timestamp_tag}"
|
||||
test x"${SAMBA_CI_IS_BROKEN_IMAGE}" = x"no" || { \
|
||||
echo "The image ${CI_JOB_NAME} is marked as broken and should have failed!"; \
|
||||
echo "Replace .build_image_template_force_broken with .build_image_template!"; \
|
||||
echo "Add a .samba-o3-template section at the end of the main .gitlab-ci.yml!"; \
|
||||
/bin/false; \
|
||||
}
|
||||
only:
|
||||
variables:
|
||||
#
|
||||
# You need a custom pipeline which passes
|
||||
# SAMBA_CI_REBUILD_IMAGES="yes".
|
||||
#
|
||||
# https://gitlab.com/samba-team/devel/samba/pipelines/new
|
||||
#
|
||||
- $SAMBA_CI_REBUILD_IMAGES == "yes"
|
||||
|
||||
.build_image_template_force_broken:
|
||||
extends: .build_image_template
|
||||
variables:
|
||||
SAMBA_CI_IS_BROKEN_IMAGE: "yes"
|
||||
only:
|
||||
variables:
|
||||
#
|
||||
# You need a custom pipeline which passes
|
||||
# SAMBA_CI_REBUILD_BROKEN_IMAGES="yes"
|
||||
# in order to build broken images for debugging
|
||||
#
|
||||
# https://gitlab.com/samba-team/devel/samba/pipelines/new
|
||||
#
|
||||
- $SAMBA_CI_REBUILD_BROKEN_IMAGES == "yes"
|
||||
|
||||
ubuntu2204:
|
||||
extends: .build_image_template
|
||||
|
||||
ubuntu2404:
|
||||
extends: .build_image_template
|
||||
|
||||
ubuntu2604:
|
||||
extends: .build_image_template
|
||||
|
||||
debian11:
|
||||
extends: .build_image_template
|
||||
|
||||
debian12:
|
||||
extends: .build_image_template
|
||||
|
||||
fedora43:
|
||||
extends: .build_image_template
|
||||
|
||||
debian11-32bit:
|
||||
extends: .build_image_template
|
||||
variables:
|
||||
SAMBA_CI_TEST_JOB: "samba-32bit"
|
||||
SAMBA_CI_PLATFORM: "linux/i386"
|
||||
|
||||
rocky8:
|
||||
extends: .build_image_template
|
||||
|
||||
centos9s:
|
||||
extends: .build_image_template
|
||||
|
||||
opensuse160:
|
||||
extends: .build_image_template
|
||||
|
||||
Reference in New Issue
Block a user