-
Notifications
You must be signed in to change notification settings - Fork 15
151 lines (138 loc) · 5.7 KB
/
publish-hub-nightly.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
name: DockerHub-Nightly
on:
schedule:
- cron: "0 0 * * *"
env:
TMP_LOCAL_IMAGE: localhost:5000/${{ github.repository }}
REGISTRY_IMAGE: ${{ github.repository }}
REGISTRY_TAG: nightly
VERSION: nightly
BRANCH: development
jobs:
build:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
platform:
- linux/amd64
- linux/arm/v6
- linux/arm/v7
- linux/arm64
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Prepare
run: |
mkdir -p /tmp/images
platform=${{ matrix.platform }}
echo "TARFILE=${platform//\//-}.tar" >> $GITHUB_ENV
echo "TAG=${{ env.TMP_LOCAL_IMAGE }}:${platform//\//-}" >> $GITHUB_ENV
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Build
uses: docker/build-push-action@v4
with:
context: .
platforms: ${{ matrix.platform }}
build-args: |
BRANCH=${{ env.BRANCH }}
VERSION=${{ env.VERSION }}
tags: ${{ env.TAG }}
outputs: type=docker,dest=/tmp/images/${{ env.TARFILE }}
- name: Load images
run: |
for image in /tmp/images/*.tar; do
docker load -i $image
done
- name: Run Docker Container and Test (1st run)
run: |
platform=${{ matrix.platform }}
docker network create --subnet=172.18.0.0/24 custom_network
docker run -d --network custom_network --ip 172.18.0.3 -p 8080:8080 -p 11470:11470 -e NO_CORS=1 -e CASTING_DISABLED=1 --platform ${{ matrix.platform }} ${{ env.TMP_LOCAL_IMAGE }}:${platform//\//-}
npm install @playwright/test
npx playwright install --with-deps
sleep 10 # wait for server to startup
cd tests
npx playwright test || (
docker ps -a;
docker logs $(docker ps -a | grep stremio | awk '{print $1}');
exit 1;
)
docker logs $(docker ps -a | grep stremio | awk '{print $1}');
docker stop $(docker ps -a | grep stremio | awk '{print $1}')
docker rm $(docker ps -a | grep stremio | awk '{print $1}')
- name: Run Docker Container and Test (2nd run with IPADDRESS)
run: |
platform=${{ matrix.platform }}
echo "172.18.0.3 172-18-0-3.519b6502d940.stremio.rocks" | sudo tee -a /etc/hosts
docker run -d --network custom_network --ip 172.18.0.3 -p 8080:8080 -p 12470:12470 -e NO_CORS=1 -e CASTING_DISABLED=1 -e IPADDRESS=172.18.0.3 -v ~/.stremio-server:/root/.stremio-server --platform ${{ matrix.platform }} ${{ env.TMP_LOCAL_IMAGE }}:${platform//\//-}
cd tests
sleep 10 # wait for server to startup
WEB_URL="https://172-18-0-3.519b6502d940.stremio.rocks:8080" SERVER_URL="https://172-18-0-3.519b6502d940.stremio.rocks:12470" npx playwright test || (
docker ps -a;
docker logs $(docker ps -a | grep stremio | awk '{print $1}');
exit 1;
)
docker logs $(docker ps -a | grep stremio | awk '{print $1}');
docker stop $(docker ps -a | grep stremio | awk '{print $1}')
docker rm $(docker ps -a | grep stremio | awk '{print $1}')
- name: Run Docker Container and Test (3rd run with CERT_FILE and DOMAIN)
run: |
platform=${{ matrix.platform }}
sudo rm -f ~/.stremio-server/httpsCert.json
docker run -d --network custom_network --ip 172.18.0.3 -p 8080:8080 -p 12470:12470 -e NO_CORS=1 -e CASTING_DISABLED=1 -e CERT_FILE=172-18-0-3.519b6502d940.stremio.rocks.pem -e DOMAIN=172-18-0-3.519b6502d940.stremio.rocks -v ~/.stremio-server:/root/.stremio-server --platform ${{ matrix.platform }} ${{ env.TMP_LOCAL_IMAGE }}:${platform//\//-}
cd tests
sleep 10 # wait for server to startup
WEB_URL="https://172-18-0-3.519b6502d940.stremio.rocks:8080" SERVER_URL="https://172-18-0-3.519b6502d940.stremio.rocks:12470" npx playwright test || (
docker ps -a;
docker logs $(docker ps -aq);
exit 1;
)
docker logs $(docker ps -a | grep stremio | awk '{print $1}');
docker stop $(docker ps -a | grep stremio | awk '{print $1}')
docker rm $(docker ps -a | grep stremio | awk '{print $1}')
- name: Upload image
uses: actions/upload-artifact@v3
with:
name: images
path: /tmp/images/${{ env.TARFILE }}
if-no-files-found: error
retention-days: 1
push:
runs-on: ubuntu-latest
needs:
- build
services:
registry:
image: registry:2
ports:
- 5000:5000
steps:
- name: Download images
uses: actions/download-artifact@v3
with:
name: images
path: /tmp/images
- name: Load images
run: |
for image in /tmp/images/*.tar; do
docker load -i $image
done
- name: Push images to local registry
run: |
docker push -a ${{ env.TMP_LOCAL_IMAGE }}
- name: Login to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_HUB_USERNAME }}
password: ${{ secrets.DOCKER_HUB_PASS }}
- name: Create manifest list and push
run: |
docker buildx imagetools create -t ${{ env.REGISTRY_IMAGE }}:${{ env.REGISTRY_TAG }} \
$(docker image ls --format '{{.Repository}}:{{.Tag}}' '${{ env.TMP_LOCAL_IMAGE }}' | tr '\n' ' ')
- name: Inspect image
run: |
docker buildx imagetools inspect ${{ env.REGISTRY_IMAGE }}:${{ env.REGISTRY_TAG }}