Skip to content

Commit

Permalink
build: Merge pull request #947 from keindev/dev
Browse files Browse the repository at this point in the history
build: release v7.0.0

- close #906
  • Loading branch information
Daniil Ryazanov authored Nov 26, 2022
2 parents ca839d1 + 9a112d2 commit e862d0e
Show file tree
Hide file tree
Showing 18 changed files with 3,241 additions and 4,348 deletions.
10 changes: 1 addition & 9 deletions .config/.vscode/launch.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,7 @@
"console": "integratedTerminal",
"cwd": "${workspaceFolder}",
"runtimeExecutable": "node",
"runtimeArgs": [
"--experimental-specifier-resolution=node",
"--nolazy",
"--inspect-brk=9229",
"--loader",
"ts-node/esm",
"example/app.js"
],
"port": 9229
"runtimeArgs": ["--nolazy", "--inspect-brk=9229", "--loader", "ts-node/esm", "example/app.js"]
}
]
}
6 changes: 2 additions & 4 deletions .ghinfo
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "tasktree-cli",
"version": "6.0.5",
"version": "7.0.0",
"description": "Simple terminal task tree - helps you keep track of your tasks in a tree structure.",
"keywords": [
"ascii",
Expand All @@ -25,8 +25,6 @@
"npm": "https://www.npmjs.com/package/tasktree-cli"
},
"files": {
"banner": "media/banner.svg",
"demo": "media/demo.gif",
"logo": "media/logo.svg"
"demo": "media/demo.gif"
}
}
File renamed without changes.
28 changes: 0 additions & 28 deletions .github/scripts/config.js

This file was deleted.

28 changes: 16 additions & 12 deletions .github/workflows/auto-merge.yml
Original file line number Diff line number Diff line change
@@ -1,20 +1,24 @@
name: Auto merge

on:
pull_request:
branches:
- 'dev'
name: Dependabot auto-merge
on: pull_request

permissions:
pull-requests: write
contents: write
pull-requests: write

jobs:
auto-merge:
dependabot:
runs-on: ubuntu-latest
if: ${{ github.actor == 'dependabot[bot]' }}
steps:
- uses: actions/checkout@v2
- uses: ahmadnassri/action-dependabot-auto-merge@v2
- name: Dependabot metadata
id: metadata
uses: dependabot/fetch-metadata@v1.1.1
with:
target: minor
github-token: ${{ secrets.AUTO_MERGE_TOKEN }}
github-token: "${{ secrets.GITHUB_TOKEN }}"
- name: Enable auto-merge for Dependabot PRs
if: ${{steps.metadata.outputs.update-type == 'version-update:semver-patch'}}
run: gh pr merge --auto --merge "$PR_URL"
env:
PR_URL: ${{github.event.pull_request.html_url}}
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}

163 changes: 25 additions & 138 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,49 +10,19 @@ on:
- '*'

jobs:
config:
name: Configure
runs-on: ubuntu-latest
outputs:
config: ${{ steps.set-config.outputs.config }}
steps:
- name: Checkout repository
uses: actions/checkout@v2

- name: Setup Node.js
uses: actions/setup-node@v2

- name: Create config
id: set-config
run: |
echo Node: $(node -v)
echo NPM: $(npm -v)
npm i semver
CONFIG=$(node ./.github/scripts/config.js | sed 's/ //g')
echo "::set-output name=config::$CONFIG"
echo $CONFIG
test:
name: Test
needs: [ config ]
strategy:
matrix: ${{ fromJson(needs.config.outputs.config).node.matrix }}
runs-on: ${{ matrix.os }}
runs-on: ubuntu-latest
env:
NODE_VERSION: 16
steps:
- name: Checkout repository
uses: actions/checkout@v2
uses: actions/checkout@v3

- name: Setup Node.js v${{ matrix.node }}
uses: actions/setup-node@v2
with:
node-version: ${{ matrix.node }}

- name: Cache node modules
id: cache-npm
uses: actions/cache@v2
- name: Setup Node.js v${{ env.NODE_VERSION }}
uses: actions/setup-node@v3
with:
path: ~/.npm
key: npm-${{ runner.os }}-${{ matrix.node }}-${{ hashFiles('**/package-lock.json') }}
node-version: ${{ env.NODE_VERSION }}

- name: Install Dependencies
run: npm ci
Expand All @@ -65,34 +35,26 @@ jobs:
npm run test
- name: Cache coverage
if: ${{ success() && matrix.node == '16.x' }}
uses: actions/cache@v2
uses: actions/cache@v3
with:
path: coverage
key: coverage-${{ runner.os }}-${{ matrix.node }}-${{ hashFiles('src/**/*.*', '**/package-lock.json') }}
key: coverage-${{ runner.os }}-${{ env.NODE_VERSION }}-${{ hashFiles('src/**/*.*', '**/package-lock.json') }}

build:
name: Build
needs: [ test, config ]
needs: [ test ]
runs-on: ubuntu-latest
env:
NODE_VERSION: ${{ fromJson(needs.config.outputs.config).node.main.version }}
runs-on: ${{ fromJson(needs.config.outputs.config).node.main.os }}
NODE_VERSION: 16
steps:
- name: Checkout repository
uses: actions/checkout@v2
uses: actions/checkout@v3

- name: Use Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v2
uses: actions/setup-node@v3
with:
node-version: ${{ env.NODE_VERSION }}

- name: Cache node modules
id: cache-npm
uses: actions/cache@v2
with:
path: ~/.npm
key: npm-${{ runner.os }}-${{ env.NODE_VERSION }}-${{ hashFiles('**/package-lock.json') }}

- name: Install Dependencies
run: npm ci
env:
Expand All @@ -104,35 +66,27 @@ jobs:
coverage:
name: Coverage
if: ${{ github.event_name == 'push' }}
needs: [ build, config ]
needs: [ build ]
runs-on: ubuntu-latest
env:
NODE_VERSION: ${{ fromJson(needs.config.outputs.config).node.main.version }}
runs-on: ${{ fromJson(needs.config.outputs.config).node.main.os }}
NODE_VERSION: 16
steps:
- name: Checkout repository
uses: actions/checkout@v2
uses: actions/checkout@v3

- name: Cache coverage
id: cache-coverage
uses: actions/cache@v2
uses: actions/cache@v3
with:
path: coverage
key: coverage-${{ runner.os }}-${{ env.NODE_VERSION }}-${{ hashFiles('src/**/*.*', '**/package-lock.json') }}

- name: Setup Node.js v${{ env.NODE_VERSION }}
if: steps.cache-coverage.outputs.cache-hit != 'true'
uses: actions/setup-node@v2
uses: actions/setup-node@v3
with:
node-version: ${{ env.NODE_VERSION }}

- name: Cache node modules
if: steps.cache-coverage.outputs.cache-hit != 'true'
id: cache-npm
uses: actions/cache@v2
with:
path: ~/.npm
key: npm-${{ runner.os }}-${{ env.NODE_VERSION }}-${{ hashFiles('**/package-lock.json') }}

- name: Test
if: steps.cache-coverage.outputs.cache-hit != 'true'
run: |
Expand All @@ -142,7 +96,7 @@ jobs:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

- name: Send coverage report
uses: codecov/codecov-action@v1
uses: codecov/codecov-action@v3
with:
file: ./coverage/lcov.info

Expand All @@ -159,77 +113,10 @@ jobs:
USER: admin:${{ secrets.GITHUB_TOKEN }}
FILTER: "[.jobs[] | select(.status==\"completed\" and .conclusion==\"failure\") | { status: .conclusion, matrix: .name}] | length"
run: |
failure_count=$(curl -X GET -s -u $USER $URL | jq "$FILTER")
echo "::set-output name=failure_count::$failure_count"
echo Failure jobs count: $failure_count
FAILURE_COUNT=$(curl -X GET -s -u $USER $URL | jq "$FILTER")
echo "fails=$FAILURE_COUNT" >> $GITHUB_OUTPUT
echo Failure jobs count: $FAILURE_COUNT
- if: ${{ steps.status.outputs.failure_count > 0 }}
- if: ${{ steps.status.outputs.fails > 0 }}
name: Fail
run: exit 1

discord:
name: Discord notification
needs: [ status ]
if: ${{ always() }}
runs-on: ubuntu-latest
env:
DISCORD_USERNAME: github
DISCORD_ERROR_COLOR: 16726645
DISCORD_ERROR_AVATAR: https://cdn.jsdelivr.net/gh/tagproject/art/bot/bot-error.png
DISCORD_EVENT_COLOR: 53759
DISCORD_EVENT_AVATAR: https://cdn.jsdelivr.net/gh/tagproject/art/bot/bot-event.png
steps:
- name: Send error notification after push commit
if: ${{ contains(needs.*.result, 'failure') && github.event_name == 'push' }}
uses: sarisia/actions-status-discord@v1
with:
webhook: ${{ secrets.DISCORD_WEBHOOK }}
nodetail: true
username: ${{ env.DISCORD_USERNAME }}
avatar_url: ${{ env.DISCORD_ERROR_AVATAR }}
title: 'Build failed :confused:'
color: ${{ env.DISCORD_ERROR_COLOR }}
description: |
**Repository:** `${{ github.repository }}`
**Branch:** `${{ github.event.ref }}`
**Author:** [${{ github.event.head_commit.author.username }}](https://github.com/${{ github.event.head_commit.author.username }})
**Commit:** [${{ github.event.head_commit.id }}](${{ github.event.head_commit.url }})
**Message:**
`${{ github.event.head_commit.message }}`
- name: Send error notification for pull_request
if: ${{ contains(needs.*.result, 'failure') && github.event_name == 'pull_request' }}
uses: sarisia/actions-status-discord@v1
with:
webhook: ${{ secrets.DISCORD_WEBHOOK }}
nodetail: true
username: ${{ env.DISCORD_USERNAME }}
avatar_url: ${{ env.DISCORD_ERROR_AVATAR }}
title: 'Pull request build failed :confused:'
color: ${{ env.DISCORD_ERROR_COLOR }}
description: |
**Repository:** `${{ github.repository }}`
**Merge:** into `${{ github.event.pull_request.base.ref }}` from `${{ github.event.pull_request.head.ref }}`
**Title:** ${{ github.event.pull_request.title }} [#${{ github.event.pull_request.number }}](${{github.event.pull_request._links.html.href}})
**Assignees:** `${{ join(github.event.pull_request.assignees.*.login, ', ') }}`
**Labels:** `${{ join(github.event.pull_request.labels.*.name, ', ') }}`
- name: Send success notification for pull_request
if: ${{ !contains(needs.*.result, 'failure') && github.event_name == 'pull_request' }}
uses: sarisia/actions-status-discord@v1
with:
webhook: ${{ secrets.DISCORD_WEBHOOK }}
nodetail: true
username: ${{ env.DISCORD_USERNAME }}
avatar_url: ${{ env.DISCORD_EVENT_AVATAR }}
title: 'Pull request successfully build :face_with_monocle:'
color: ${{ env.DISCORD_EVENT_COLOR }}
description: |
**Repository:** `${{ github.repository }}`
**Merge:** into `${{ github.event.pull_request.base.ref }}` from `${{ github.event.pull_request.head.ref }}`
**Title:** ${{ github.event.pull_request.title }} [#${{ github.event.pull_request.number }}](${{github.event.pull_request._links.html.href}})
**Assignees:** `${{ join(github.event.pull_request.assignees.*.login, ', ') }}`
**Labels:** `${{ join(github.event.pull_request.labels.*.name, ', ') }}`
Loading

0 comments on commit e862d0e

Please sign in to comment.