diff options
| author | rtm516 <ryantmilner@hotmail.co.uk> | 2026-03-17 22:02:24 +0000 |
|---|---|---|
| committer | rtm516 <ryantmilner@hotmail.co.uk> | 2026-03-17 22:02:24 +0000 |
| commit | 76f4832a6b66c63f7f065d6ff0ccf6ccee77d9d1 (patch) | |
| tree | b89b89590e17202aa6d8a2418a592677ddd56180 | |
| parent | 02a5961f39673be403fda3edbf6fb1265bd93477 (diff) | |
Fix actions and sort docker nightly
| -rw-r--r-- | .github/workflows/docker-nightly.yml | 160 | ||||
| -rw-r--r-- | .github/workflows/nightly-server.yml | 78 | ||||
| -rw-r--r-- | .github/workflows/nightly.yml | 14 |
3 files changed, 82 insertions, 170 deletions
diff --git a/.github/workflows/docker-nightly.yml b/.github/workflows/docker-nightly.yml deleted file mode 100644 index 78d5256c..00000000 --- a/.github/workflows/docker-nightly.yml +++ /dev/null @@ -1,160 +0,0 @@ -name: Docker Nightly Dedicated Server - -on: - workflow_dispatch: - push: - branches: - - "main" - - 'feature/dedicated-server' - paths-ignore: - - ".gitignore" - - "*.md" - - ".github/*.md" - -permissions: - contents: read - packages: write - -concurrency: - group: docker-nightly-dedicated-server - cancel-in-progress: true - -jobs: - build-runtime: - name: Build Dedicated Server Runtime - runs-on: windows-latest - - steps: - - name: Checkout - uses: actions/checkout@v6 - - - name: Setup msbuild - uses: microsoft/setup-msbuild@v2 - - - name: Build Dedicated Server Runtime Only - shell: pwsh - run: | - MSBuild.exe Minecraft.World\Minecraft.World.vcxproj /p:Configuration=Release /p:Platform=x64 /m - MSBuild.exe Minecraft.Server\Minecraft.Server.vcxproj /p:Configuration=Release /p:Platform=x64 /m - - - name: Stage dedicated server runtime - shell: pwsh - run: | - $serverOut = "Minecraft.Server/x64/Minecraft.Server/Release" - $stage = ".artifacts/dedicated-server-runtime" - - if (Test-Path $stage) { - Remove-Item -Path $stage -Recurse -Force - } - - New-Item -ItemType Directory -Path (Join-Path $stage "Windows64") -Force | Out-Null - - # Minimum required runtime files - $required = @( - "Minecraft.Server.exe", - "iggy_w64.dll", - "Common" - ) - - foreach ($entry in $required) { - $src = Join-Path $serverOut $entry - if (-not (Test-Path $src)) { - throw "Missing required runtime path: $src" - } - } - - # Copy required files - Copy-Item -Path (Join-Path $serverOut "Minecraft.Server.exe") -Destination (Join-Path $stage "Minecraft.Server.exe") -Force - Copy-Item -Path (Join-Path $serverOut "iggy_w64.dll") -Destination (Join-Path $stage "iggy_w64.dll") -Force - Copy-Item -Path (Join-Path $serverOut "Common") -Destination (Join-Path $stage "Common") -Recurse -Force - if (Test-Path (Join-Path $serverOut "Windows64")) { - Copy-Item -Path (Join-Path $serverOut "Windows64/*") -Destination (Join-Path $stage "Windows64") -Recurse -Force - } else { - Write-Host "Windows64 directory is not present in build output; staging without it." - } - - Get-ChildItem -Path $stage -Recurse -File | Select-Object -First 20 | ForEach-Object { - Write-Host "Staged: $($_.FullName)" - } - - - name: Upload dedicated server runtime to artifacts - uses: actions/upload-artifact@v4 - with: - name: dedicated-server-runtime - if-no-files-found: error - path: | - .artifacts/dedicated-server-runtime/** - - docker-publish: - name: Build and Push Docker Image - runs-on: ubuntu-latest - needs: build-runtime - - steps: - - name: Checkout - uses: actions/checkout@v6 - - - name: Download dedicated server runtime from artifacts - uses: actions/download-artifact@v4 - with: - name: dedicated-server-runtime - path: .artifacts/runtime - - - name: Prepare Docker runtime directory - shell: bash - run: | - set -euo pipefail - - rm -rf runtime - mkdir -p runtime - cp .artifacts/runtime/Minecraft.Server.exe runtime/Minecraft.Server.exe - cp .artifacts/runtime/iggy_w64.dll runtime/iggy_w64.dll - cp -R .artifacts/runtime/Common runtime/Common - mkdir -p runtime/Windows64 - if [[ -d ".artifacts/runtime/Windows64" ]]; then - cp -R .artifacts/runtime/Windows64/. runtime/Windows64/ - fi - - test -f runtime/Minecraft.Server.exe - test -f runtime/iggy_w64.dll - test -d runtime/Common - test -d runtime/Windows64 - - - name: Compute image name - id: image - shell: bash - run: | - owner="$(echo "${{ vars.CONTAINER_REGISTRY_OWNER || github.repository_owner }}" | tr '[:upper:]' '[:lower:]')" - image_tag="nightly" - # if [[ "${{ github.ref }}" != "refs/heads/main" ]]; then - # image_tag="nightly-test" - # fi - echo "owner=$owner" >> "$GITHUB_OUTPUT" - echo "image=ghcr.io/$owner/minecraft-lce-dedicated-server" >> "$GITHUB_OUTPUT" - echo "image_tag=$image_tag" >> "$GITHUB_OUTPUT" - - - name: Extract Docker metadata - id: meta - uses: docker/metadata-action@v5 - with: - images: ${{ steps.image.outputs.image }} - tags: | - type=raw,value=${{ steps.image.outputs.image_tag }} - - - name: Login to GHCR - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ secrets.GHCR_USERNAME || github.actor }} - password: ${{ secrets.GHCR_TOKEN || secrets.GITHUB_TOKEN }} - - - name: Build and push image - uses: docker/build-push-action@v6 - with: - context: . - file: docker/dedicated-server/Dockerfile - push: true - tags: ${{ steps.meta.outputs.tags }} - labels: ${{ steps.meta.outputs.labels }} - build-args: | - MC_RUNTIME_DIR=runtime
\ No newline at end of file diff --git a/.github/workflows/nightly-server.yml b/.github/workflows/nightly-server.yml index a55a2a62..23ea2cb7 100644 --- a/.github/workflows/nightly-server.yml +++ b/.github/workflows/nightly-server.yml @@ -13,6 +13,11 @@ on: permissions: contents: write + packages: write + +concurrency: + group: nightly-server + cancel-in-progress: true jobs: build: @@ -27,7 +32,7 @@ jobs: uses: actions/checkout@v6 - name: Set platform lowercase - run: echo "PLATFORM=$('${{ matrix.platform }}'.ToLower())" >> $env:GITHUB_ENV + run: echo "MATRIX_PLATFORM=$('${{ matrix.platform }}'.ToLower())" >> $env:GITHUB_ENV - name: Setup MSVC uses: ilammy/msvc-dev-cmd@v1 @@ -40,12 +45,12 @@ jobs: env: VCPKG_ROOT: "" # Disable vcpkg for CI builds with: - configurePreset: ${{ env.PLATFORM }} - buildPreset: ${{ env.PLATFORM }}-release + configurePreset: ${{ env.MATRIX_PLATFORM }} + buildPreset: ${{ env.MATRIX_PLATFORM }}-release buildPresetAdditionalArgs: "['--target', 'Minecraft.Server']" - name: Zip Build - run: 7z a -r LCEServer${{ matrix.platform }}.zip ./build/${{ env.PLATFORM }}/Minecraft.Server/Release/* -x!*.ipdb -x!*.iobj + run: 7z a -r LCEServer${{ matrix.platform }}.zip ./build/${{ env.MATRIX_PLATFORM }}/Minecraft.Server/Release/* -x!*.ipdb -x!*.iobj - name: Stage artifacts run: | @@ -55,7 +60,7 @@ jobs: - name: Stage exe and pdb if: matrix.platform == 'Windows64' run: | - Copy-Item ./build/${{ env.PLATFORM }}/Minecraft.Server/Release/Minecraft.Server.exe staging/ + Copy-Item ./build/${{ env.MATRIX_PLATFORM }}/Minecraft.Server/Release/Minecraft.Server.exe staging/ - name: Upload artifacts uses: actions/upload-artifact@v6 @@ -88,6 +93,69 @@ jobs: files: | artifacts/* + docker-publish: + name: Build and Push Docker Image + runs-on: ubuntu-latest + needs: build + + steps: + - name: Checkout + uses: actions/checkout@v6 + + - name: Download dedicated server runtime from artifacts + uses: actions/download-artifact@v4 + with: + name: build-Windows64 + path: .artifacts/ + + - name: Prepare Docker runtime directory + shell: bash + run: | + set -euo pipefail + + rm -rf runtime + mkdir -p runtime + unzip .artifacts/LCEServerWindows64.zip -d runtime + + - name: Compute image name + id: image + shell: bash + run: | + owner="$(echo "${{ vars.CONTAINER_REGISTRY_OWNER || github.repository_owner }}" | tr '[:upper:]' '[:lower:]')" + image_tag="nightly" + # if [[ "${{ github.ref }}" != "refs/heads/main" ]]; then + # image_tag="nightly-test" + # fi + echo "owner=$owner" >> "$GITHUB_OUTPUT" + echo "image=ghcr.io/$owner/minecraft-lce-dedicated-server" >> "$GITHUB_OUTPUT" + echo "image_tag=$image_tag" >> "$GITHUB_OUTPUT" + + - name: Extract Docker metadata + id: meta + uses: docker/metadata-action@v5 + with: + images: ${{ steps.image.outputs.image }} + tags: | + type=raw,value=${{ steps.image.outputs.image_tag }} + + - name: Login to GHCR + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ secrets.GHCR_USERNAME || github.actor }} + password: ${{ secrets.GHCR_TOKEN || secrets.GITHUB_TOKEN }} + + - name: Build and push image + uses: docker/build-push-action@v6 + with: + context: . + file: docker/dedicated-server/Dockerfile + push: true + tags: ${{ steps.meta.outputs.tags }} + labels: ${{ steps.meta.outputs.labels }} + build-args: | + MC_RUNTIME_DIR=runtime + cleanup: needs: [build, release] if: always() diff --git a/.github/workflows/nightly.yml b/.github/workflows/nightly.yml index ad3a816a..19f6e138 100644 --- a/.github/workflows/nightly.yml +++ b/.github/workflows/nightly.yml @@ -14,6 +14,10 @@ on: permissions: contents: write +concurrency: + group: nightly + cancel-in-progress: true + jobs: build: runs-on: windows-latest @@ -27,7 +31,7 @@ jobs: uses: actions/checkout@v6 - name: Set platform lowercase - run: echo "PLATFORM=$('${{ matrix.platform }}'.ToLower())" >> $env:GITHUB_ENV + run: echo "MATRIX_PLATFORM=$('${{ matrix.platform }}'.ToLower())" >> $env:GITHUB_ENV - name: Setup MSVC uses: ilammy/msvc-dev-cmd@v1 @@ -40,12 +44,12 @@ jobs: env: VCPKG_ROOT: "" # Disable vcpkg for CI builds with: - configurePreset: ${{ env.PLATFORM }} - buildPreset: ${{ env.PLATFORM }}-release + configurePreset: ${{ env.MATRIX_PLATFORM }} + buildPreset: ${{ env.MATRIX_PLATFORM }}-release buildPresetAdditionalArgs: "['--target', 'Minecraft.Client']" - name: Zip Build - run: 7z a -r LCE${{ matrix.platform }}.zip ./build/${{ env.PLATFORM }}/Minecraft.Client/Release/* -x!*.ipdb -x!*.iobj + run: 7z a -r LCE${{ matrix.platform }}.zip ./build/${{ env.MATRIX_PLATFORM }}/Minecraft.Client/Release/* -x!*.ipdb -x!*.iobj - name: Stage artifacts run: | @@ -55,7 +59,7 @@ jobs: - name: Stage exe and pdb if: matrix.platform == 'Windows64' run: | - Copy-Item ./build/${{ env.PLATFORM }}/Minecraft.Client/Release/Minecraft.Client.exe staging/ + Copy-Item ./build/${{ env.MATRIX_PLATFORM }}/Minecraft.Client/Release/Minecraft.Client.exe staging/ - name: Upload artifacts uses: actions/upload-artifact@v6 |
