Skip to content

Commit

Permalink
Move binaries build to GitHub Actions (#528)
Browse files Browse the repository at this point in the history
  • Loading branch information
lucacome authored Feb 2, 2024
1 parent 027cf92 commit 0b8e437
Show file tree
Hide file tree
Showing 11 changed files with 182 additions and 208 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
13 changes: 13 additions & 0 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,28 @@ updates:
directory: "/"
schedule:
interval: daily

- package-ecosystem: "docker"
directory: "/build"
schedule:
interval: "daily"

- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: daily

- package-ecosystem: "pip"
directory: "/test"
schedule:
interval: "daily"

- package-ecosystem: "pip"
directory: "/test/environment/grpc"
schedule:
interval: "daily"
groups:
grpc-test:
update-types:
- "minor"
- "patch"
89 changes: 89 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
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/draft-release@v1.0.1
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: 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
provenance: mode=max
sbom: 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/ ngx_http_opentracing_module.so
cp out/provenance.json linux-amd64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.provenance.json
cp out/sbom.spdx.json linux-amd64-nginx-${{ matrix.nginx_version }}-ngx_http_module.so.sbom.spdx.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.

Loading

0 comments on commit 0b8e437

Please sign in to comment.