Skip to content

Commit

Permalink
ci: add option to enable monitoring stack (#2927)
Browse files Browse the repository at this point in the history
* ci: add option to enable monitoring stack

* start prometheus faster

* update
  • Loading branch information
gartnera authored Sep 27, 2024
1 parent 3eeb78a commit 0e5bca6
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 6 deletions.
9 changes: 9 additions & 0 deletions .github/workflows/e2e.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,11 @@ on:
description: 'Comma separated list of make targets to run (without the start- prefix)'
required: true
default: ''
enable-monitoring:
description: 'Enable the monitoring stack'
required: true
type: boolean
default: false

concurrency:
group: e2e-${{ github.head_ref || github.sha }}
Expand All @@ -40,6 +45,7 @@ jobs:
TON_TESTS: ${{ steps.matrix-conditionals.outputs.TON_TESTS }}
V2_TESTS: ${{ steps.matrix-conditionals.outputs.V2_TESTS }}
V2_MIGRATION_TESTS: ${{ steps.matrix-conditionals.outputs.V2_MIGRATION_TESTS }}
ENABLE_MONITORING: ${{ steps.matrix-conditionals.outputs.ENABLE_MONITORING }}
steps:
# use api rather than event context to avoid race conditions (label added after push)
- id: matrix-conditionals
Expand All @@ -66,6 +72,7 @@ jobs:
core.setOutput('TON_TESTS', labels.includes('TON_TESTS'));
core.setOutput('V2_TESTS', labels.includes('V2_TESTS')); // for v2 tests, TODO: remove this once we fully migrate to v2 (https://github.com/zeta-chain/node/issues/2627)
core.setOutput('V2_MIGRATION_TESTS', labels.includes('V2_MIGRATION_TESTS')); // for v2 tests, TODO: remove this once we fully migrate to v2 (https://github.com/zeta-chain/node/issues/2627)
core.setOutput('ENABLE_MONITORING', labels.includes('ENABLE_MONITORING'));
} else if (context.eventName === 'merge_group') {
core.setOutput('DEFAULT_TESTS', true);
core.setOutput('UPGRADE_LIGHT_TESTS', true);
Expand Down Expand Up @@ -110,6 +117,7 @@ jobs:
core.setOutput('TON_TESTS', makeTargets.includes('ton-test'));
core.setOutput('V2_TESTS', makeTargets.includes('v2-test')); // for v2 tests, TODO: remove this once we fully migrate to v2 (https://github.com/zeta-chain/node/issues/2627)
core.setOutput('V2_MIGRATION_TESTS', makeTargets.includes('v2-migration-test')); // for v2 tests, TODO: remove this once we fully migrate to v2 (https://github.com/zeta-chain/node/issues/2627)
core.setOutput('ENABLE_MONITORING', context.payload.inputs['enable-monitoring']);
}
e2e:
Expand Down Expand Up @@ -164,6 +172,7 @@ jobs:
runs-on: ${{ matrix.runs-on}}
run: ${{ matrix.run }}
timeout-minutes: "${{ matrix.timeout-minutes || 25 }}"
enable-monitoring: ${{ needs.matrix-conditionals.outputs.ENABLE_MONITORING == 'true' }}
secrets: inherit
# this allows you to set a required status check
e2e-ok:
Expand Down
14 changes: 14 additions & 0 deletions .github/workflows/reusable-e2e.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,10 @@ on:
required: true
type: string
default: 'ubuntu-20.04'
enable-monitoring:
description: 'Enable the monitoring stack for this run'
type: boolean
default: false

jobs:
e2e:
Expand Down Expand Up @@ -80,9 +84,19 @@ jobs:
cache-to: ${{ github.event_name == 'push' && env.CACHE_TO_CONFIG || '' }}
target: latest-runtime

- name: Enable monitoring
if: inputs.enable-monitoring
run: |
echo "NODE_COMPOSE_ARGS=${NODE_COMPOSE_ARGS:-} --profile monitoring --profile monitoring-cloudflared" >> $GITHUB_ENV
- name: Start Test
run: make ${{ inputs.make-target }}

- name: Get grafana URL
if: inputs.enable-monitoring
run: |
docker logs grafana-cloudflared 2>&1 | grep -oP 'https?://\S+\.trycloudflare\.com'
# use docker logs -f rather than docker attach to make sure we get the initial logs
- name: Watch Test
run: |
Expand Down
29 changes: 23 additions & 6 deletions contrib/localnet/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -313,7 +313,7 @@ services:
- ssh:/root/.ssh

grafana:
image: grafana/grafana:11.2.0
image: ghcr.io/zeta-chain/grafana-grafana:11.2.0
container_name: grafana
hostname: grafana
profiles:
Expand All @@ -333,7 +333,7 @@ services:
- prometheus

prometheus:
image: prom/prometheus:v2.53.1
image: ghcr.io/zeta-chain/prom-prometheus:v2.53.1
container_name: prometheus
hostname: prometheus
profiles:
Expand All @@ -345,8 +345,7 @@ services:
mynetwork:
ipv4_address: 172.20.0.31
depends_on:
zetacore0:
condition: service_healthy
- zetacore0

zetachain-exporter:
image: zetachain/zetachain-exporter:v2.0.6
Expand Down Expand Up @@ -377,7 +376,7 @@ services:

loki:
container_name: loki
image: grafana/loki:3.1.0
image: ghcr.io/zeta-chain/grafana-loki:3.1.0
hostname: loki
profiles:
- monitoring
Expand All @@ -389,7 +388,7 @@ services:

promtail:
container_name: promtail
image: grafana/promtail:2.9.9
image: ghcr.io/zeta-chain/grafana-promtail:2.9.9
hostname: promtail
profiles:
- monitoring
Expand All @@ -402,6 +401,24 @@ services:
- /var/run/docker.sock:/var/run/docker.sock
command: -config.file=/etc/promtail/config.yaml

grafana-cloudflared:
container_name: grafana-cloudflared
image: ghcr.io/zeta-chain/cloudflare-cloudflared:2024.9.1
hostname: grafana-cloudflared
profiles:
- monitoring-cloudflared
- all
command:
- tunnel
- --no-autoupdate
- --url
- http://grafana:3000
networks:
mynetwork:
ipv4_address: 172.20.0.35
depends_on:
- grafana

volumes:
ssh:
preparams:
Expand Down

0 comments on commit 0e5bca6

Please sign in to comment.