Integrate DockerImages within Gitea #1
@@ -8,10 +8,10 @@ on:
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
BRANCH_NAME: ${{ github.ref_name }}
|
BRANCH_NAME: ${{ github.ref_name }}
|
||||||
BASE_BUILDER_TAG: ${{ vars.CI_REGISTRY_IMAGE }}/linuxbasebuilder:${{ github.ref_name }}
|
BASE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbasebuilder:${{ github.ref_name }}
|
||||||
CPP_BUILDER_TAG: ${{ vars.CI_REGISTRY_IMAGE }}/linuxcppbuilder:${{ github.ref_name }}
|
CPP_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxcppbuilder:${{ github.ref_name }}
|
||||||
BIGFOOT_BUILDER_TAG: ${{ vars.CI_REGISTRY_IMAGE }}/linuxbigfootbuilder:${{ github.ref_name }}
|
BIGFOOT_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootbuilder:${{ github.ref_name }}
|
||||||
BIGFOOT_COVERAGE_BUILDER_TAG: ${{ vars.CI_REGISTRY_IMAGE }}/linuxbigfootcoveragebuilder:${{ github.ref_name }}
|
BIGFOOT_COVERAGE_BUILDER_TAG: ${{ vars.DOCKER_IMAGE }}/linuxbigfootcoveragebuilder:${{ github.ref_name }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-base-builder:
|
build-base-builder:
|
||||||
@@ -28,9 +28,9 @@ jobs:
|
|||||||
- name: Login to the Container registry
|
- name: Login to the Container registry
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
registry: ${{ vars.CI_REGISTRY }}
|
registry: ${{ vars.DOCKER_REGISTRY }}
|
||||||
username: ${{ secrets.CI_USERNAME }}
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
password: ${{ secrets.CI_TOKEN }}
|
password: ${{ secrets.DOCKER_TOKEN }}
|
||||||
|
|
||||||
- name: Build and push base builder
|
- name: Build and push base builder
|
||||||
uses: docker/build-push-action@v5
|
uses: docker/build-push-action@v5
|
||||||
@@ -54,9 +54,9 @@ jobs:
|
|||||||
- name: Login to the Container registry
|
- name: Login to the Container registry
|
||||||
uses: docker/login-action@v3
|
uses: docker/login-action@v3
|
||||||
with:
|
with:
|
||||||
registry: ${{ vars.CI_REGISTRY }}
|
registry: ${{ vars.DOCKER_REGISTRY }}
|
||||||
username: ${{ secrets.CI_USERNAME }}
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
password: ${{ secrets.CI_TOKEN }}
|
password: ${{ secrets.DOCKER_TOKEN }}
|
||||||
|
|
||||||
- name: Build and push cpp builder
|
- name: Build and push cpp builder
|
||||||
uses: docker/build-push-action@v5
|
uses: docker/build-push-action@v5
|
||||||
@@ -67,3 +67,37 @@ jobs:
|
|||||||
build-args: |
|
build-args: |
|
||||||
BASE_BUILDER=${{ env.BASE_BUILDER_TAG }}
|
BASE_BUILDER=${{ env.BASE_BUILDER_TAG }}
|
||||||
CONAN_PROFILE_BRANCH=${{ env.BRANCH_NAME }}
|
CONAN_PROFILE_BRANCH=${{ env.BRANCH_NAME }}
|
||||||
|
|
||||||
|
build-bigfoot-builder:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 360
|
||||||
|
needs: build-base-builder
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v6
|
||||||
|
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v3
|
||||||
|
|
||||||
|
- name: Login to the Container registry
|
||||||
|
uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: ${{ vars.DOCKER_REGISTRY }}
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_TOKEN }}
|
||||||
|
|
||||||
|
- name: Build and push cpp builder
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: ./Linux/BigfootBuilder
|
||||||
|
push: true
|
||||||
|
tags: ${{ env.BIGFOOT_BUILDER_TAG }}
|
||||||
|
build-args: |
|
||||||
|
BASE_BUILDER=${{ env.CPP_BUILDER_TAG }}
|
||||||
|
ARTIFACTORY_CONAN_USER=${{ secrets.ARTIFACTORY_USER }}
|
||||||
|
ARTIFACTORY_CONAN_PASSWORD=${{ secrets.ARTIFACTORY_PASSWORD }}
|
||||||
|
CONAN_RELEASE_PROFILE=clang
|
||||||
|
CONAN_RELWITHDEBINFO_PROFILE=clangd
|
||||||
|
CONAN_DEBUG_PROFILE=clangd
|
||||||
|
PACKAGES_CHANNEL=${{ github.ref_name }}
|
||||||
|
|||||||
@@ -5,20 +5,31 @@ FROM $BASE_BUILDER
|
|||||||
ARG CONAN_RELEASE_PROFILE
|
ARG CONAN_RELEASE_PROFILE
|
||||||
ARG CONAN_RELWITHDEBINFO_PROFILE
|
ARG CONAN_RELWITHDEBINFO_PROFILE
|
||||||
ARG CONAN_DEBUG_PROFILE
|
ARG CONAN_DEBUG_PROFILE
|
||||||
|
ARG ARTIFACTORY_CONAN_USER
|
||||||
|
ARG ARTIFACTORY_CONAN_PASSWORD
|
||||||
|
ARG PACKAGES_CHANNEL
|
||||||
|
|
||||||
RUN wget -qO - https://packages.lunarg.com/lunarg-signing-key-pub.asc | sudo apt-key add
|
RUN apt-get update \
|
||||||
RUN wget -qO /etc/apt/sources.list.d/lunarg-vulkan-1.4.313-noble.list https://packages.lunarg.com/vulkan/1.4.313/lunarg-vulkan-1.4.313-noble.list
|
&& apt-get install -y \
|
||||||
RUN apt-get update -y
|
gcovr \
|
||||||
RUN apt-get install gcovr -y
|
xvfb \
|
||||||
RUN apt-get install vulkan-sdk -y
|
\
|
||||||
RUN apt-get install xvfb -y
|
# LunarG Vulkan repo (modern keyring method)
|
||||||
|
&& wget -qO /usr/share/keyrings/lunarg-archive-keyring.gpg https://packages.lunarg.com/lunarg-signing-key-pub.asc; \
|
||||||
|
&& echo "deb [signed-by=/usr/share/keyrings/lunarg-archive-keyring.gpg] https://packages.lunarg.com/vulkan/1.4.313 noble main" \
|
||||||
|
> /etc/apt/sources.list.d/lunarg-vulkan.list \
|
||||||
|
\
|
||||||
|
&& apt-get update \
|
||||||
|
&& apt-get install -y vulkan-sdk \
|
||||||
|
\
|
||||||
|
# Cleanup
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
COPY conanfile.py BigfootDependencies/conanfile.py
|
COPY conanfile.py BigfootDependencies/conanfile.py
|
||||||
|
|
||||||
RUN ccache --zero-stats
|
RUN ccache --zero-stats \
|
||||||
|
&& CONAN_LOGIN_USERNAME=${ARTIFACTORY_CONAN_USER} CONAN_PASSWORD=${ARTIFACTORY_CONAN_PASSWORD} conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELEASE_PROFILE} -pr:b=${CONAN_RELEASE_PROFILE} -s build_type=Release \
|
||||||
RUN CONAN_LOGIN_USERNAME=${GITLAB_CONAN_USER} CONAN_PASSWORD=${GITLAB_CONAN_PASSWORD} conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELEASE_PROFILE} -pr:b=${CONAN_RELEASE_PROFILE} -s build_type=Release && \
|
&& CONAN_LOGIN_USERNAME=${ARTIFACTORY_CONAN_USER} CONAN_PASSWORD=${ARTIFACTORY_CONAN_PASSWORD} conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELWITHDEBINFO_PROFILE} -pr:b=${CONAN_RELWITHDEBINFO_PROFILE} -s build_type=RelWithDebInfo \
|
||||||
CONAN_LOGIN_USERNAME=${GITLAB_CONAN_USER} CONAN_PASSWORD=${GITLAB_CONAN_PASSWORD} conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_RELWITHDEBINFO_PROFILE} -pr:b=${CONAN_RELWITHDEBINFO_PROFILE} -s build_type=RelWithDebInfo && \
|
&& CONAN_LOGIN_USERNAME=${ARTIFACTORY_CONAN_USER} CONAN_PASSWORD=${ARTIFACTORY_CONAN_PASSWORD} conan install ./BigfootDependencies -o Requirements/*:packages_channel=${PACKAGES_CHANNEL} --remote=bigfootpackages --build="*" -pr:h=${CONAN_DEBUG_PROFILE} -pr:b=${CONAN_DEBUG_PROFILE} -s build_type=Debug \
|
||||||
CONAN_LOGIN_USERNAME=${GITLAB_CONAN_USER} CONAN_PASSWORD=${GITLAB_CONAN_PASSWORD} conan install ./BigfootDependencies --remote=bigfootpackages --build="*" -pr:h=${CONAN_DEBUG_PROFILE} -pr:b=${CONAN_DEBUG_PROFILE} -s build_type=Debug
|
&& ccache --show-stats \
|
||||||
|
&& CONAN_LOGIN_USERNAME=${ARTIFACTORY_CONAN_USER} CONAN_PASSWORD=${ARTIFACTORY_CONAN_PASSWORD} conan upload "*" --remote=bigfootpackages --force --confirm
|
||||||
RUN ccache --show-stats
|
|
||||||
@@ -3,6 +3,13 @@ from conan import ConanFile
|
|||||||
class RequirementsConan(ConanFile):
|
class RequirementsConan(ConanFile):
|
||||||
name = "Requirements"
|
name = "Requirements"
|
||||||
|
|
||||||
|
options = {
|
||||||
|
"packages_channel"
|
||||||
|
}
|
||||||
|
default_options = {
|
||||||
|
"packages_channel": "main"
|
||||||
|
}
|
||||||
|
|
||||||
def configure(self):
|
def configure(self):
|
||||||
self.options['stduuid'].with_cxx20_span = True
|
self.options['stduuid'].with_cxx20_span = True
|
||||||
self.options['flatbuffers'].header_only = True
|
self.options['flatbuffers'].header_only = True
|
||||||
@@ -15,17 +22,15 @@ class RequirementsConan(ConanFile):
|
|||||||
self.options["benchmark"].enable_lto = True
|
self.options["benchmark"].enable_lto = True
|
||||||
|
|
||||||
def requirements(self):
|
def requirements(self):
|
||||||
self.requires("eastl/3.27.01")
|
self.requires(f"eastl/3.27.01@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("unordered_dense/4.8.1")
|
self.requires(f"unordered_dense/4.8.1@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("mimalloc/3.1.5")
|
self.requires(f"mimalloc/3.1.5@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("magic_enum/0.9.7")
|
self.requires(f"stduuid/1.2.3@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("stduuid/1.2.3")
|
self.requires(f"sqlite3/3.51.0@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("sqlite3/3.51.0")
|
|
||||||
self.requires("cli11/2.6.0")
|
self.requires("cli11/2.6.0")
|
||||||
self.requires("xxhash/0.8.3")
|
self.requires(f"rapidhash/3.0@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("effolkronium-random/1.5.0")
|
self.requires("effolkronium-random/1.5.0")
|
||||||
self.requires("zeus_expected/1.3.0")
|
self.requires(f"flatbuffers/25.12.19@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("flatbuffers/25.9.23")
|
|
||||||
|
|
||||||
self.requires("quill/11.0.2")
|
self.requires("quill/11.0.2")
|
||||||
self.requires("tracy/0.12.2")
|
self.requires("tracy/0.12.2")
|
||||||
@@ -38,17 +43,17 @@ class RequirementsConan(ConanFile):
|
|||||||
self.requires("glfw/3.4")
|
self.requires("glfw/3.4")
|
||||||
|
|
||||||
self.requires("vulkan-headers/1.4.313.0")
|
self.requires("vulkan-headers/1.4.313.0")
|
||||||
self.requires("vulkan-validationlayers/1.4.313.0")
|
self.requires(f"vulkan-validationlayers/1.4.313.0@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("spirv-cross/1.4.313.0")
|
self.requires("spirv-cross/1.4.313.0")
|
||||||
self.requires("vulkan-memory-allocator/3.3.0")
|
self.requires(f"vulkan-memory-allocator/3.3.0@bigfootdev/{self.options['packages_channel']}")
|
||||||
|
|
||||||
self.requires("gtest/1.17.0")
|
self.requires("gtest/1.17.0")
|
||||||
self.requires("pixelmatch-cpp17/1.0.3")
|
self.requires(f"pixelmatch-cpp17/1.0.3@bigfootdev/{self.options['packages_channel']}")
|
||||||
|
|
||||||
self.requires("stb/cci.20240531", override=True)
|
self.requires("stb/cci.20240531", override=True)
|
||||||
self.requires("shaderc/2025.3")
|
self.requires(f"shaderc/2025.3@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("assimp/6.0.2")
|
self.requires("assimp/6.0.2")
|
||||||
self.requires("meshoptimizer/1.0")
|
self.requires(f"meshoptimizer/1.0@bigfootdev/{self.options['packages_channel']}")
|
||||||
self.requires("libsquish/1.15")
|
self.requires("libsquish/1.15")
|
||||||
|
|
||||||
self.requires("benchmark/1.9.4")
|
self.requires("benchmark/1.9.4")
|
||||||
|
|||||||
Reference in New Issue
Block a user