From 905abca83bacc40496174ade92da31a15b105cee Mon Sep 17 00:00:00 2001 From: ahmadtaimoor-deriv <129935294+ahmadtaimoor-deriv@users.noreply.github.com> Date: Fri, 2 Feb 2024 18:07:39 +0800 Subject: [PATCH] [DTRA]Ahmad/DTRA-791/Smartcharts preview links (#1487) * chore: setup preview link generation * chore: remove unused workflows * chore: add PAT * chore: remove deriv-app deploy * new changes * generate link * testing test link * test link * test link * test link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * testing link * add concurrency * replaxing names * Update .github/CODEOWNERS * Update .github/workflows/generate_preview_link.yml * Update .github/workflows/generate_preview_link.yml * Update .github/workflows/generate_preview_link.yml * github action ecosystem added --------- Co-authored-by: balakrishna-binary Co-authored-by: balakrishna-deriv <56330681+balakrishna-deriv@users.noreply.github.com> --- .github/CODEOWNERS | 6 + .github/actions/checkout/action.yml | 68 ++++++++++ .github/dependabot.yml | 10 ++ .../generate_and_push_deriv_charts.yml | 4 +- .github/workflows/generate_preview_link.yml | 126 ++++++++++++++++++ .github/workflows/release-automation.yml | 54 -------- .github/workflows/tag-release.yml | 26 ---- scripts/deriv-app-deploy.sh | 6 - 8 files changed, 212 insertions(+), 88 deletions(-) create mode 100644 .github/CODEOWNERS create mode 100644 .github/actions/checkout/action.yml create mode 100644 .github/dependabot.yml create mode 100644 .github/workflows/generate_preview_link.yml delete mode 100644 .github/workflows/release-automation.yml delete mode 100644 .github/workflows/tag-release.yml delete mode 100644 scripts/deriv-app-deploy.sh diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 0000000000..4043f6e4ab --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1,6 @@ +# Configuration of code ownership and review approvals for the binary-com/deriv-app repo. +# +# More info: https://help.github.com/articles/about-codeowners/ +# + +* @binary-com/write-admin-smartcharts diff --git a/.github/actions/checkout/action.yml b/.github/actions/checkout/action.yml new file mode 100644 index 0000000000..ddccf418bc --- /dev/null +++ b/.github/actions/checkout/action.yml @@ -0,0 +1,68 @@ +name: Checkout + +inputs: + fetch-depth: + default: 1 + required: false + type: number + path: + required: false + type: string + repository: + default: ${{ github.repository }} + required: false + type: string + ref: + required: false + type: string + alternate_repository: + required: false + type: string + alternate_ref: + required: false + type: string + token: + default: ${{ github.token }} + required: false + type: string + +outputs: + ref_exists: + description: 'Specifies whether the ref exists or not' + value: ${{ steps.repo.outputs.ref-exists }} + +runs: + using: composite + + steps: + - id: repo + shell: bash + env: + GH_TOKEN: ${{ inputs.token }} + run: | + if git ls-remote --heads --quiet --exit-code https://${{ inputs.token }}@github.com/${{ inputs.repository }}.git ${{ inputs.ref }} + then + echo "::notice::Checkout: ${{ inputs.repository }} using ${{ inputs.ref }}" + echo "ref-exists=true" >> $GITHUB_OUTPUT + else + echo "::notice::Checkout: ${{ inputs.repository }} does not have ref ${{ inputs.ref }} (fallback to ${{ inputs.alternate_ref }})" + echo "ref-exists=false" >> $GITHUB_OUTPUT + fi + + - if: steps.repo.outputs.ref-exists == 'true' + uses: actions/checkout@a12a3943b4bdde767164f792f33f40b04645d846 + with: + fetch-depth: ${{ inputs.fetch-depth }} + path: ${{ inputs.path }} + repository: ${{ inputs.repository }} + ref: ${{ inputs.ref }} + token: ${{ inputs.token }} + + - if: steps.repo.outputs.ref-exists == 'false' + uses: actions/checkout@a12a3943b4bdde767164f792f33f40b04645d846 + with: + fetch-depth: ${{ inputs.fetch-depth }} + path: ${{ inputs.path }} + repository: ${{ inputs.alternate_repository }} + ref: ${{ inputs.alternate_ref }} + token: ${{ inputs.token }} diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000000..a276517bb5 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,10 @@ +version: 2 +updates: + - package-ecosystem: npm + directory: "/" + schedule: + interval: daily + - package-ecosystem: "github-actions" + directory: "/" + schedule: + interval: "daily" diff --git a/.github/workflows/generate_and_push_deriv_charts.yml b/.github/workflows/generate_and_push_deriv_charts.yml index f4cdc0eac7..c34397f672 100644 --- a/.github/workflows/generate_and_push_deriv_charts.yml +++ b/.github/workflows/generate_and_push_deriv_charts.yml @@ -9,7 +9,7 @@ jobs: steps: - name: Setup node and npm id: step1 - uses: actions/setup-node@v2 + uses: actions/setup-node@9ced9a43a244f3ac94f13bfd896db8c8f30da67a with: node-version: '18' check-latest: true @@ -18,7 +18,7 @@ jobs: NODE_AUTH_TOKEN: ${{ secrets.NPM_ACCESS_TOKEN }} - name: Checkout repo id: step2 - uses: actions/checkout@v3 + uses: actions/checkout@a12a3943b4bdde767164f792f33f40b04645d846 with: fetch-depth: 1 ref: master diff --git a/.github/workflows/generate_preview_link.yml b/.github/workflows/generate_preview_link.yml new file mode 100644 index 0000000000..4f2d8621e0 --- /dev/null +++ b/.github/workflows/generate_preview_link.yml @@ -0,0 +1,126 @@ +name: Generate preview link + +on: + pull_request_target: + types: [opened, synchronize] + +concurrency: + group: cloudflare-pages-build-${{ github.head_ref }} + cancel-in-progress: true + +jobs: + build_and_deploy_preview_link: + runs-on: Ubuntu-latest + permissions: + checks: write + pull-requests: write + steps: + - name: Verify user + uses: "deriv-com/shared-actions/.github/actions/verify_user_in_organization@v1" + with: + username: ${{github.event.pull_request.user.login}} + token: ${{ secrets.PERSONAL_ACCESS_TOKEN }} + + - name: Post preview build comment + id: post_preview_build_comment + uses: 'deriv-com/shared-actions/.github/actions/post_preview_build_comment@v1' + with: + issue_number: ${{github.event.number}} + head_sha: ${{github.event.pull_request.head.sha}} + + - name: Checkout SmartCharts + uses: 'binary-com/SmartCharts/.github/actions/checkout@master' + with: + repository: ${{github.event.pull_request.user.login}}/SmartCharts + path: SmartCharts + ref: ${{github.head_ref}} + alternate_repository: 'binary-com/SmartCharts' + alternate_ref: master + + - name: Checkout deriv-app + uses: 'binary-com/SmartCharts/.github/actions/checkout@master' + with: + repository: ${{github.event.pull_request.user.login}}/deriv-app + path: deriv-app + ref: ${{github.head_ref}} + alternate_repository: 'binary-com/deriv-app' + alternate_ref: master + + - name: Custom flutter-chart + uses: 'binary-com/SmartCharts/.github/actions/checkout@master' + with: + repository: ${{github.event.pull_request.user.login}}/flutter-chart + path: flutter-chart + ref: ${{github.head_ref}} + alternate_repository: 'regentmarkets/flutter-chart' + alternate_ref: fe-changes + token: ${{ secrets.REPO_READ_TOKEN }} + + - uses: subosito/flutter-action@v2 + with: + flutter-version: '3.10.6' + channel: 'stable' + cache: true + + - name: Add SSH key + run: | + mkdir -p ~/.ssh + echo "${{ secrets.SSH_KEY }}" > ~/.ssh/github_action_key + chmod 600 ~/.ssh/github_action_key + + - name: Build flutter + env: + GIT_SSH_COMMAND: 'ssh -i ~/.ssh/github_action_key' + run: | + cd SmartCharts/chart_app + flutter pub get + flutter build web --web-renderer html --release + + - name: Setup Node + uses: actions/setup-node@b39b52d1213e96004bfcb1c61a8a6fa8ab84f3e8 + with: + node-version: 18.x + + - name: Setup deriv-app + run: cd deriv-app && npm install && npm run bootstrap + + - name: Remove @deriv-charts in deriv-app + run: rm -rf deriv-app/node_modules/@deriv/deriv-charts/dist + + - name: Setup SmartCharts + run: cd SmartCharts && npm install + + - name: Build SmartCharts + run: cd SmartCharts && npm run build -- --output-path ../deriv-app/node_modules/@deriv/deriv-charts/dist + + - name: Run Tests + run: cd SmartCharts && npm run test + + - name: Build deriv-app + env: + NODE_ENV: 'production' + run: cd deriv-app && npm run build:all + + - name: Setup Node + uses: actions/setup-node@9ced9a43a244f3ac94f13bfd896db8c8f30da67a + with: + node-version: 20 + + - name: Publish to CF pages branch + id: publish_to_pages_branch + uses: 'deriv-com/shared-actions/.github/actions/publish_to_pages_branch@v1' + with: + CLOUDFLARE_API_TOKEN: ${{ secrets.CLOUDFLARE_TEST_LINKS_API_TOKEN }} + CLOUDFLARE_ACCOUNT_ID: ${{ secrets.CLOUDFLARE_TEST_LINKS_ACCOUNT_ID }} + project_name: 'smartcharts-preview' + branch_name: 'pr-${{github.event.number}}' + output_dir: deriv-app/packages/core/dist + + - name: 'Generate preview link comment' + if: always() && steps.post_preview_build_comment.outcome == 'success' + uses: 'deriv-com/shared-actions/.github/actions/post_preview_link_comment@v1' + with: + issue_number: ${{github.event.number}} + check_run_id: ${{steps.post_preview_build_comment.outputs.check_run_id}} + preview_url: ${{steps.publish_to_pages_branch.outputs.cf_pages_url}} + status: ${{job.status}} diff --git a/.github/workflows/release-automation.yml b/.github/workflows/release-automation.yml deleted file mode 100644 index a1f7464eff..0000000000 --- a/.github/workflows/release-automation.yml +++ /dev/null @@ -1,54 +0,0 @@ -name: Release automation for SmartCharts -permissions: - pull-requests: write -on: - workflow_dispatch: - inputs: - tag: - description: 'Tag' - required: true - skip_circleci_checks: - description: 'Skip checking CircleCI workflow' - type: boolean - required: false - skip_pending_checks: - description: 'Skip waiting for pull request checks' - type: boolean - required: false - - -concurrency: - group: release_automation_group - -jobs: - release_issues: - permissions: write-all - runs-on: ubuntu-latest - steps: - - name: Checkout to repo - uses: actions/checkout@v3 - with: - ref: master - - name: Setup node - uses: actions/setup-node@v2 - - name: Wait for logs to accumulate - run: | - sleep 10 - - name: Release issues in SmartCharts - uses: binary-com/fe-toolbox@production_V20230602_0 - with: - tag: ${{ inputs.tag }} - list_id: ${{ secrets.LIST_ID }} - platform: 'deriv-charts' - release_tags_list_id: ${{ secrets.RELEASE_TAGS_LIST_ID }} - regression_testing_template_id: ${{ secrets.REGRESSION_TESTING_TEMPLATE_ID }} - circleci_project_slug: 'gh/binary-com/SmartCharts' - circleci_workflow_name: 'release_staging' - skip_circleci_checks: ${{ inputs.skip_circleci_checks }} - skip_pending_checks: ${{ inputs.skip_pending_checks }} - CIRCLECI_TOKEN: ${{ secrets.CIRCLECI_TOKEN }} - CLICKUP_API_TOKEN: ${{ secrets.CLICKUP_API_TOKEN }} - SLACK_APP_TOKEN: ${{ secrets.SLACK_APP_TOKEN }} - SLACK_USER_TOKEN: ${{ secrets.SLACK_USER_TOKEN }} - SLACK_BOT_TOKEN: ${{ secrets.SLACK_BOT_TOKEN }} - GITHUB_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN }} \ No newline at end of file diff --git a/.github/workflows/tag-release.yml b/.github/workflows/tag-release.yml deleted file mode 100644 index da54cf213e..0000000000 --- a/.github/workflows/tag-release.yml +++ /dev/null @@ -1,26 +0,0 @@ -name: Tag for SmartCharts release - -permissions: write-all - -on: - workflow_dispatch: - inputs: - tag: - description: 'Tag' - required: true - -jobs: - create-tag: - runs-on: ubuntu-latest - - steps: - - name: Checkout code - uses: actions/checkout@v2 - - - name: Create and release tag - run: | - git config --global user.name "DerivFE" - git config --global user.email "fe-access@deriv.com" - - git tag ${{ inputs.tag }} ${{ github.ref }} - git push origin ${{ inputs.tag }} diff --git a/scripts/deriv-app-deploy.sh b/scripts/deriv-app-deploy.sh deleted file mode 100644 index 3ad4470911..0000000000 --- a/scripts/deriv-app-deploy.sh +++ /dev/null @@ -1,6 +0,0 @@ -npm run build -rm -rf node_modules && rm .*rc *.js *.ts && rm -rf deriv-app -git clone https://github.com/binary-com/deriv-app.git --depth 1 -cd deriv-app && npm run bootstrap && rm -rf node_modules/@deriv/deriv-charts/dist && cd .. -cp -R dist deriv-app/node_modules/@deriv/deriv-charts/ -cd deriv-app && npm run build:prod