Skip to content

Commit

Permalink
Move binaries build to GitHub Actions
Browse files Browse the repository at this point in the history
  • Loading branch information
lucacome committed Oct 29, 2023
1 parent 177bbd1 commit e5c2a13
Show file tree
Hide file tree
Showing 9 changed files with 174 additions and 192 deletions.
70 changes: 1 addition & 69 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,65 +39,14 @@ jobs:
- checkout
- run:
command: docker build -t opentracing/openresty -f Dockerfile-openresty .
module_binaries_opentracing_15:
docker:
- image: ubuntu:18.04
environment:
OPENTRACING_VERSION: v1.5.1
MODULE_DIR: /workspace/modules
steps:
- checkout
- run: mkdir -p /workspace/modules
- run: ./ci/setup_build_environment.sh
- run:
name: Build modules with opentracing v1.5.1
command: ./ci/do_ci.sh module.binaries
- store_artifacts:
path: /workspace/modules
- persist_to_workspace:
root: /workspace
paths:
- modules
module_binaries_opentracing_16:
docker:
- image: ubuntu:18.04
environment:
OPENTRACING_VERSION: v1.6.0
MODULE_DIR: /workspace/modules
NAME_SUFFIX: "-ot16"
steps:
- checkout
- run: ./ci/setup_build_environment.sh
- attach_workspace:
at: /workspace
- run:
name: Build modules with opentracing v1.6.0
command: ./ci/do_ci.sh module.binaries
- store_artifacts:
path: /workspace/modules
- persist_to_workspace:
root: /workspace
paths:
- modules

push_docker_image:
machine: true
steps:
- checkout
- run:
command: ./ci/do_ci.sh push_docker_image

release:
docker:
- image: ubuntu:18.04
environment:
MODULE_DIR: /workspace/modules
steps:
- run: apt-get -qq update; apt-get -y install git ssh
- checkout
- attach_workspace:
at: /workspace
- run: ./ci/setup_build_environment.sh
- run: ./ci/do_ci.sh release

workflows:
version: 2
Expand All @@ -109,14 +58,6 @@ workflows:
ignore: /.*/
tags: &tags
only: /^v[0-9]+(\.[0-9]+)*$/
- release:
requires:
- module_binaries_opentracing_15
- module_binaries_opentracing_16
filters:
branches:
ignore: /.*/
tags: *tags
- system_testing
- build_gcc48_opentracing_15
- build_gcc48_opentracing_16:
Expand All @@ -125,12 +66,3 @@ workflows:
- openresty_docker_image:
requires:
- system_testing
- module_binaries_opentracing_15:
filters:
tags: *tags

- module_binaries_opentracing_16:
requires:
- module_binaries_opentracing_15
filters:
tags: *tags
94 changes: 94 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
name: CI

on:
push:
branches:
- master
tags:
- "v[0-9]+.[0-9]+.[0-9]+"
pull_request:
branches:
- master

concurrency:
group: ${{ github.ref_name }}-ci
cancel-in-progress: true

jobs:
build-binaries:
name: Build Binaries
runs-on: ubuntu-20.04
strategy:
matrix:
nginx_version:
[
1.15.12,
1.16.1,
1.17.10,
1.18.0,
1.19.10,
1.20.2,
1.21.6,
1.22.1,
1.23.4,
1.24.0,
1.25.0,
1.25.1,
1.25.2,
1.25.3,
]
steps:
- name: Checkout Repository
uses: actions/checkout@v4

- name: Create/Update Draft
uses: lucacome/[email protected]
with:
minor-label: "enhancement"
major-label: "change"
publish: ${{ github.ref_type == 'tag' }}
collapse-after: 50
if: github.event_name != 'pull_request'

- name: Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Setup QEMU
uses: docker/setup-qemu-action@v3
with:
platforms: arm64

- name: Build binary
uses: docker/build-push-action@v5
with:
pull: true
push: false
file: build/Dockerfile
tags: ${{ matrix.nginx_version }}
cache-from: type=gha,scope=${{ matrix.nginx_version }}
cache-to: type=gha,scope=${{ matrix.nginx_version }},mode=max
platforms: linux/amd64,linux/arm64
provenance: true
target: export
build-args: NGINX_VERSION=${{ matrix.nginx_version }}
outputs: type=local,dest=out

- name: Compress output
run: |
tar -czf linux-amd64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.tgz -C out/linux_amd64/ ngx_http_opentracing_module.so
tar -czf linux-arm64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.tgz -C out/linux_arm64/ ngx_http_opentracing_module.so
cp out/linux_amd64/provenance.json linux-amd64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.provenance.json
cp out/linux_arm64/provenance.json linux-arm64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.provenance.json
- name: Upload artifact
uses: actions/upload-artifact@v3
with:
name: nginx-opentracing-modules-${{ matrix.nginx_version }}
path: linux-*-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.*

- name: Upload binaries on release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
if: github.ref_type == 'tag'
run: |
gh release upload ${{ github.ref_name }} linux-*-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.* --clobber
23 changes: 0 additions & 23 deletions .github/workflows/draft-release.yml

This file was deleted.

5 changes: 5 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -36,3 +36,8 @@ test-log/

# IDEs
.vscode

# macOS
.DS_Store

out
74 changes: 74 additions & 0 deletions build/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
FROM ubuntu:23.10 as base

RUN apt-get update && \
apt-get install --no-install-recommends --no-install-suggests -y \
build-essential \
cmake \
pkg-config \
git \
ca-certificates \
automake \
autogen \
autoconf \
libtool \
ssh \
wget \
libpcre3 libpcre3-dev \
zlib1g-dev

ENV CFLAGS="-fPIC"
ENV CXXFLAGS="-fPIC"
ENV LDFLAGS="-fPIC"


FROM base as opentracing
ARG OPENTRACING_VERSION=v1.6.0

RUN <<"eot" bash -euo pipefail
git clone -b "${OPENTRACING_VERSION}" https://github.com/opentracing/opentracing-cpp.git
cd opentracing-cpp
mkdir .build && cd .build
cmake -DCMAKE_BUILD_TYPE=Release \
-DCMAKE_CXX_FLAGS="-fPIC" \
-DBUILD_SHARED_LIBS=OFF \
-DBUILD_TESTING=OFF \
-DBUILD_MOCKTRACER=OFF \
..
make && make install
eot


FROM opentracing as binary
ARG NGINX_VERSION

COPY --link opentracing /opentracing

ADD --link https://github.com/nginx/nginx/archive/release-${NGINX_VERSION}.tar.gz /
RUN tar zxf release-${NGINX_VERSION}.tar.gz
WORKDIR /nginx-release-${NGINX_VERSION}

COPY <<-EOT export.map
{
global:
ngx_*;
local: *;
};
EOT

RUN ./auto/configure \
--with-compat \
--add-dynamic-module=/opentracing \
&& make modules

RUN /usr/bin/g++ -o ngx_http_opentracing_module.so \
objs/addon/src/*.o \
objs/ngx_http_opentracing_module_modules.o \
-static-libstdc++ -static-libgcc \
-lopentracing \
-Wl,--version-script="export.map" \
-shared


FROM scratch as export
ARG NGINX_VERSION
COPY --from=binary /nginx-release-${NGINX_VERSION}/ngx_http_opentracing_module.so /
19 changes: 0 additions & 19 deletions ci/build_module_binaries.sh

This file was deleted.

43 changes: 0 additions & 43 deletions ci/build_module_binary.sh

This file was deleted.

9 changes: 0 additions & 9 deletions ci/do_ci.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ set -e

[ -z "${SRC_DIR}" ] && export SRC_DIR="$(pwd)"
[ -z "${BUILD_DIR}" ] && export BUILD_DIR=/build
[ -z "${MODULE_DIR}" ] && export MODULE_DIR=/modules

if [[ "$1" == "system.testing" ]]; then
docker build -t nginx-opentracing-test/nginx -f Dockerfile-test .
Expand All @@ -19,11 +18,6 @@ elif [[ "$1" == "build" ]]; then
mkdir -p "${BUILD_DIR}"
./ci/build_nginx_opentracing_module.sh
exit 0
elif [[ "$1" == "module.binaries" ]]; then
mkdir -p "${BUILD_DIR}"
mkdir -p "${MODULE_DIR}"
./ci/build_module_binaries.sh
exit 0
elif [[ "$1" == "push_docker_image" ]]; then
echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USERNAME" --password-stdin
VERSION_TAG="$(git describe --abbrev=0 --tags)"
Expand All @@ -36,9 +30,6 @@ elif [[ "$1" == "push_docker_image" ]]; then
docker tag opentracing/openresty opentracing/openresty:latest
docker push opentracing/openresty:latest
exit 0
elif [[ "$1" == "release" ]]; then
./ci/release.sh
exit 0
else
echo "Invalid do_ci.sh target"
exit 1
Expand Down
Loading

0 comments on commit e5c2a13

Please sign in to comment.