Remove zone diagnostics and retire ARMv7 workflow
parent
d4a91ba18e
commit
15cddec357
@ -1,103 +0,0 @@
|
||||
name: docker-armv7
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: [master]
|
||||
paths-ignore:
|
||||
- '.github/**'
|
||||
- '.vscode/**'
|
||||
- 'chrome-extension/**'
|
||||
- 'releases/**'
|
||||
- '**/**.md'
|
||||
- '**.crx'
|
||||
- '**.pem'
|
||||
- '.dockerignore'
|
||||
- '.gitignore'
|
||||
schedule:
|
||||
- cron: '49 4 * * 2'
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
push_image:
|
||||
description: 'Push image to registry'
|
||||
required: true
|
||||
default: 'false'
|
||||
type: choice
|
||||
options:
|
||||
- 'true'
|
||||
- 'false'
|
||||
image_tag:
|
||||
description: 'Docker tag prefix (workflow appends -armv7)'
|
||||
required: true
|
||||
default: 'test'
|
||||
type: string
|
||||
|
||||
concurrency:
|
||||
group: docker-armv7-${{ github.ref }}
|
||||
cancel-in-progress: true
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
steps:
|
||||
- name: checkout code
|
||||
uses: actions/checkout@v6
|
||||
|
||||
- name: Set hash
|
||||
id: vars
|
||||
run: echo "sha_short=$(git rev-parse --short HEAD)" >> "$GITHUB_OUTPUT"
|
||||
|
||||
- name: Get current date
|
||||
id: date
|
||||
run: echo "date=$(date +'%Y-%m-%d')" >> "$GITHUB_OUTPUT"
|
||||
|
||||
- name: create-json
|
||||
id: create-json
|
||||
uses: jsdaniell/create-json@v1.2.3
|
||||
with:
|
||||
name: "version.json"
|
||||
json: '{"type": "docker", "tag": "${{secrets.DOCKERHUB_MASTER_TAG}}-armv7", "commit": "${{ steps.vars.outputs.sha_short }}", "date": "${{ steps.date.outputs.date }}"}'
|
||||
dir: 'backend/'
|
||||
|
||||
- name: setup platform emulator
|
||||
uses: docker/setup-qemu-action@v3
|
||||
|
||||
- name: setup multi-arch docker build
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Set push and tag values
|
||||
id: build_params
|
||||
run: |
|
||||
if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then
|
||||
echo "push=${{ github.event.inputs.push_image }}" >> "$GITHUB_OUTPUT"
|
||||
echo "tags=${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPO }}:${{ github.event.inputs.image_tag }}-armv7,ghcr.io/${{ github.repository_owner }}/${{ secrets.DOCKERHUB_REPO }}:${{ github.event.inputs.image_tag }}-armv7" >> "$GITHUB_OUTPUT"
|
||||
else
|
||||
echo "push=true" >> "$GITHUB_OUTPUT"
|
||||
echo "tags=${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPO }}:${{ secrets.DOCKERHUB_MASTER_TAG }}-armv7,${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPO }}:${{ secrets.DOCKERHUB_MASTER_TAG }}-${{ steps.date.outputs.date }}-armv7,${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPO }}:sha-${{ steps.vars.outputs.sha_short }}-armv7,ghcr.io/${{ github.repository_owner }}/${{ secrets.DOCKERHUB_REPO }}:${{ secrets.DOCKERHUB_MASTER_TAG }}-armv7,ghcr.io/${{ github.repository_owner }}/${{ secrets.DOCKERHUB_REPO }}:${{ secrets.DOCKERHUB_MASTER_TAG }}-${{ steps.date.outputs.date }}-armv7,ghcr.io/${{ github.repository_owner }}/${{ secrets.DOCKERHUB_REPO }}:sha-${{ steps.vars.outputs.sha_short }}-armv7" >> "$GITHUB_OUTPUT"
|
||||
fi
|
||||
|
||||
- name: Login to DockerHub
|
||||
if: github.event_name != 'workflow_dispatch' || github.event.inputs.push_image == 'true'
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||
|
||||
- name: Login to GitHub Container Registry
|
||||
if: github.event_name != 'workflow_dispatch' || github.event.inputs.push_image == 'true'
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
registry: ghcr.io
|
||||
username: ${{ github.repository_owner }}
|
||||
password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
- name: build & push armv7 image
|
||||
uses: docker/build-push-action@v6
|
||||
with:
|
||||
context: .
|
||||
file: ./Dockerfile
|
||||
platforms: linux/arm/v7
|
||||
push: ${{ steps.build_params.outputs.push }}
|
||||
tags: ${{ steps.build_params.outputs.tags }}
|
||||
@ -1,96 +0,0 @@
|
||||
import { NgZone } from '@angular/core';
|
||||
|
||||
type DiagEvent = {
|
||||
ts: string;
|
||||
name: string;
|
||||
inZone: boolean;
|
||||
data?: unknown;
|
||||
};
|
||||
|
||||
type DiagState = {
|
||||
createdAt: string;
|
||||
counters: Record<string, number>;
|
||||
events: DiagEvent[];
|
||||
flags: Record<string, boolean>;
|
||||
lastHttp?: {
|
||||
kind: string;
|
||||
method?: string;
|
||||
url?: string;
|
||||
inZone: boolean;
|
||||
ts: string;
|
||||
};
|
||||
print: () => unknown;
|
||||
clear: () => void;
|
||||
};
|
||||
|
||||
const MAX_EVENTS = 200;
|
||||
|
||||
function newDiagState(): DiagState {
|
||||
const state: DiagState = {
|
||||
createdAt: new Date().toISOString(),
|
||||
counters: {},
|
||||
events: [],
|
||||
flags: {},
|
||||
print: () => ({
|
||||
createdAt: state.createdAt,
|
||||
counters: { ...state.counters },
|
||||
lastHttp: state.lastHttp,
|
||||
recentEvents: state.events.slice(-20)
|
||||
}),
|
||||
clear: () => {
|
||||
state.counters = {};
|
||||
state.events = [];
|
||||
state.lastHttp = undefined;
|
||||
}
|
||||
};
|
||||
|
||||
return state;
|
||||
}
|
||||
|
||||
export function getYdmDiag(): DiagState {
|
||||
const g = globalThis as any;
|
||||
if (!g.__ydmDiag) {
|
||||
g.__ydmDiag = newDiagState();
|
||||
}
|
||||
return g.__ydmDiag as DiagState;
|
||||
}
|
||||
|
||||
export function diagCount(name: string, amount = 1): number {
|
||||
const diag = getYdmDiag();
|
||||
diag.counters[name] = (diag.counters[name] ?? 0) + amount;
|
||||
return diag.counters[name];
|
||||
}
|
||||
|
||||
export function diagEvent(name: string, data?: unknown, printToConsole = false): void {
|
||||
const diag = getYdmDiag();
|
||||
const entry: DiagEvent = {
|
||||
ts: new Date().toISOString(),
|
||||
name,
|
||||
inZone: NgZone.isInAngularZone(),
|
||||
data
|
||||
};
|
||||
diag.events.push(entry);
|
||||
if (diag.events.length > MAX_EVENTS) {
|
||||
diag.events.splice(0, diag.events.length - MAX_EVENTS);
|
||||
}
|
||||
|
||||
if (printToConsole) {
|
||||
console.log('[YDM-DIAG]', entry.name, entry);
|
||||
}
|
||||
}
|
||||
|
||||
export function diagHttpCallback(kind: 'next' | 'error' | 'complete', method?: string, url?: string): void {
|
||||
const inZone = NgZone.isInAngularZone();
|
||||
diagCount(`http.${kind}`);
|
||||
diagCount(`http.inZone.${inZone ? 'true' : 'false'}`);
|
||||
|
||||
const diag = getYdmDiag();
|
||||
diag.lastHttp = {
|
||||
kind,
|
||||
method,
|
||||
url,
|
||||
inZone,
|
||||
ts: new Date().toISOString()
|
||||
};
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue