forked from segmentio/action-destinations
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' of https://github.com/Loops-so/action-destinations
- Loading branch information
Showing
1,289 changed files
with
65,546 additions
and
10,711 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Validating CODEOWNERS rules …
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,116 +7,178 @@ on: | |
pull_request: | ||
|
||
jobs: | ||
test-and-build: | ||
test: | ||
name: Unit tests | ||
runs-on: ubuntu-20.04 | ||
|
||
timeout-minutes: 30 | ||
|
||
strategy: | ||
matrix: | ||
node-version: [18.x] | ||
|
||
steps: | ||
- uses: actions/checkout@v2 | ||
# See nx recipe: https://nx.dev/recipes/ci/monorepo-ci-github-actions | ||
- uses: actions/checkout@v3 | ||
with: | ||
persist-credentials: false | ||
fetch-depth: 0 # nx recipe | ||
|
||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/setup-node@v2 | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version: ${{ matrix.node-version }} | ||
registry-url: 'https://registry.npmjs.org' | ||
cache: yarn | ||
|
||
- name: Get yarn cache directory path | ||
id: yarn-cache-dir-path | ||
run: echo "::set-output name=dir::$(yarn cache dir)" | ||
- name: Use Github Personal Access Token | ||
run: git config --global url."https://${{ secrets.GH_PAT }}@github.com/".insteadOf ssh://[email protected]/ | ||
|
||
- uses: actions/cache@v2 | ||
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||
- uses: nrwl/nx-set-shas@v3 # nx recipe | ||
|
||
- name: Install Dependencies | ||
run: yarn install --frozen-lockfile | ||
env: | ||
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | ||
|
||
- name: Build (Affected) | ||
run: NODE_ENV=production yarn nx affected -t build --parallel=3 # nx recipe | ||
|
||
- name: Test (Affected) | ||
run: yarn nx affected -t test --parallel=3 # nx recipe | ||
|
||
lint: | ||
name: Lint | ||
runs-on: ubuntu-20.04 | ||
timeout-minutes: 20 | ||
strategy: | ||
matrix: | ||
node-version: [18.x] | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
path: ${{ steps.yarn-cache-dir-path.outputs.dir }} | ||
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }} | ||
restore-keys: | | ||
${{ runner.os }}-yarn- | ||
persist-credentials: false | ||
fetch-depth: 0 # nx recipe | ||
|
||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version: ${{ matrix.node-version }} | ||
registry-url: 'https://registry.npmjs.org' | ||
cache: yarn | ||
|
||
- name: Use Github Personal Access Token | ||
run: git config --global url."https://${{ secrets.GH_PAT }}@github.com/".insteadOf ssh://[email protected]/ | ||
|
||
- uses: nrwl/nx-set-shas@v3 # nx recipe | ||
|
||
- name: Install Dependencies | ||
run: yarn install --frozen-lockfile | ||
env: | ||
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | ||
|
||
- name: Build | ||
run: NODE_ENV=production yarn build | ||
- name: Build # TODO: This monorepo should be refactored so packages can be linted invidually. "affected" will not work ATM. | ||
run: NODE_ENV=production yarn build # nx recipe | ||
|
||
- name: Lint | ||
env: | ||
NODE_OPTIONS: '--max-old-space-size=4096' | ||
run: yarn lint | ||
|
||
- name: Validate | ||
run: yarn validate | ||
validate: | ||
name: Validate | ||
runs-on: ubuntu-20.04 | ||
timeout-minutes: 20 | ||
strategy: | ||
matrix: | ||
node-version: [18.x] | ||
|
||
- name: Test | ||
run: yarn test | ||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
persist-credentials: false | ||
fetch-depth: 0 # nx recipe | ||
|
||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version: ${{ matrix.node-version }} | ||
registry-url: 'https://registry.npmjs.org' | ||
cache: yarn | ||
|
||
- name: Use Github Personal Access Token | ||
run: git config --global url."https://${{ secrets.GH_PAT }}@github.com/".insteadOf ssh://[email protected]/ | ||
|
||
- uses: nrwl/nx-set-shas@v3 # nx recipe | ||
|
||
- name: Install Dependencies | ||
run: yarn install --frozen-lockfile | ||
env: | ||
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | ||
|
||
- name: Assert yarn.lock is up-to-date | ||
run: bash scripts/assert-lockfile-updated.sh | ||
|
||
- name: Build # TODO: This monorepo should be refactored so packages can be linted invidually. "affected" will not work ATM. | ||
run: NODE_ENV=production yarn build # nx recipe | ||
|
||
- name: Validate Definitions | ||
run: yarn validate | ||
|
||
- name: destination-subscriptions size | ||
- name: Destination Subscription Size | ||
run: | | ||
if $(lerna changed | grep -q destination-subscriptions); then | ||
yarn subscriptions size | ||
fi | ||
# browser-tests-destination: | ||
# # env: # Disable saucelabs - we blew through our quota. | ||
# # SAUCE_USERNAME: ${{secrets.SAUCE_USERNAME}} | ||
# # SAUCE_ACCESS_KEY: ${{secrets.SAUCE_ACCESS_KEY}} | ||
- name: Assert generated types are up-to-date | ||
run: bash scripts/assert-types-updated.sh | ||
|
||
# runs-on: ubuntu-20.04 | ||
|
||
# timeout-minutes: 20 | ||
|
||
# strategy: | ||
# matrix: | ||
# node-version: [18.x] | ||
browser-destination-bundle-qa: | ||
name: Browser Destination Bundle QA | ||
# env: # Disable saucelabs - we blew through our quota. | ||
# SAUCE_USERNAME: ${{secrets.SAUCE_USERNAME}} | ||
# SAUCE_ACCESS_KEY: ${{secrets.SAUCE_ACCESS_KEY}} | ||
runs-on: ubuntu-20.04 | ||
timeout-minutes: 20 | ||
strategy: | ||
matrix: | ||
node-version: [18.x] | ||
|
||
# steps: | ||
# - uses: actions/checkout@master | ||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
persist-credentials: false | ||
|
||
# - name: Use Node.js ${{ matrix.node-version }} | ||
# uses: actions/setup-node@v2 | ||
# with: | ||
# node-version: ${{ matrix.node-version }} | ||
# registry-url: 'https://registry.npmjs.org' | ||
- name: Use Node.js ${{ matrix.node-version }} | ||
uses: actions/setup-node@v3 | ||
with: | ||
node-version: ${{ matrix.node-version }} | ||
registry-url: 'https://registry.npmjs.org' | ||
cache: yarn | ||
|
||
# - name: Get yarn cache directory path | ||
# id: yarn-cache-dir-path | ||
# run: echo "::set-output name=dir::$(yarn cache dir)" | ||
- name: Use Github Personal Access Token | ||
run: git config --global url."https://${{ secrets.GH_PAT }}@github.com/".insteadOf ssh://[email protected]/ | ||
|
||
# - uses: actions/cache@v2 | ||
# id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||
# with: | ||
# path: ${{ steps.yarn-cache-dir-path.outputs.dir }} | ||
# key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }} | ||
# restore-keys: | | ||
# ${{ runner.os }}-yarn- | ||
- name: Install Dependencies | ||
run: yarn install --frozen-lockfile | ||
env: | ||
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | ||
|
||
# - name: Install Dependencies | ||
# run: yarn install --frozen-lockfile | ||
# env: | ||
# NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }} | ||
- name: Build | ||
run: NODE_ENV=production yarn build:browser-bundles | ||
|
||
# - name: Build | ||
# run: NODE_ENV=production yarn build:browser-destinations && yarn browser build-web | ||
- name: Size Limit | ||
run: yarn browser size | ||
|
||
# - name: Run Saucelabs Tests | ||
# working-directory: packages/browser-destinations-integration-tests | ||
# shell: bash | ||
# run: | | ||
# yarn start-destination-server & | ||
# yarn test:sauce | ||
# - name: Run Saucelabs Tests | ||
# working-directory: packages/browser-destinations-integration-tests | ||
# shell: bash | ||
# run: | | ||
# yarn start-destination-server & | ||
# yarn test:sauce | ||
|
||
browser-tests-core: | ||
name: 'Browser tests: actions-core' | ||
runs-on: ubuntu-20.04 | ||
|
||
timeout-minutes: 10 | ||
|
@@ -164,6 +226,7 @@ jobs: | |
run: yarn test-browser | ||
|
||
snyk: | ||
name: Snyk | ||
runs-on: ubuntu-20.04 | ||
|
||
timeout-minutes: 5 | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# This workflow labels PRs based on the files that were changed. It uses a custom script to this | ||
# instead of actions/labeler as few of the tags are more than just file changes. | ||
|
||
name: Label PRs | ||
on: | ||
pull_request_target: | ||
types: [opened, synchronize, reopened] | ||
|
||
jobs: | ||
pr-labeler: | ||
runs-on: ubuntu-20.04 | ||
permissions: | ||
contents: read | ||
pull-requests: write | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
persist-credentials: false | ||
- name: Compute Labels | ||
id: compute-labels | ||
uses: actions/github-script@v7 | ||
with: | ||
# Required for the script to access team membership information. | ||
# Scope: members:read and contentes:read permission on the organization. | ||
github-token: ${{ secrets.GH_PAT_MEMBER_AND_PULL_REQUEST_READONLY }} | ||
script: | | ||
const script = require('./scripts/compute-labels.js') | ||
await script({github, context, core}) | ||
- name: Apply Labels | ||
uses: actions/github-script@v7 | ||
env: | ||
labelsToAdd: '${{ steps.compute-labels.outputs.add }}' | ||
labelsToRemove: '${{ steps.compute-labels.outputs.remove }}' | ||
with: | ||
script: | | ||
const { labelsToAdd, labelsToRemove } = process.env | ||
if(labelsToAdd.length > 0) { | ||
await github.rest.issues.addLabels({ | ||
issue_number: context.payload.pull_request.number, | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
labels: labelsToAdd.split(',') | ||
}); | ||
} | ||
if(labelsToRemove.length > 0) { | ||
const requests = labelsToRemove.split(',').map(label => { | ||
return github.rest.issues.removeLabel({ | ||
issue_number: context.payload.pull_request.number, | ||
name: label, | ||
owner: context.repo.owner, | ||
repo: context.repo.repo | ||
}); | ||
}); | ||
await Promise.all(requests); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,7 +2,7 @@ node_modules | |
dist | ||
.DS_Store | ||
*.log | ||
*.tsbuildinfo | ||
*.tsbuildinfo* | ||
.eslintcache | ||
package-lock.json | ||
.env | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
packages/cli-internal |
Oops, something went wrong.