feat(logging): add logs to FilterManager class #600
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
name: Rootstock Integration Tests | |
on: | |
schedule: | |
- cron: '0 0 * * *' | |
pull_request: | |
types: [ opened, synchronize, reopened ] | |
branches: ["master", "*-rc"] | |
workflow_dispatch: | |
inputs: | |
rit-branch: | |
description: 'Branch for Rootstock Integration Tests' | |
required: false | |
default: 'main' | |
powpeg-branch: | |
description: 'Branch for PowPeg Node' | |
required: false | |
default: 'master' | |
# Declare default permissions as read only. | |
permissions: read-all | |
jobs: | |
rootstock-integration-tests: | |
name: Rootstock Integration Tests | |
runs-on: ubuntu-latest | |
timeout-minutes: 60 | |
steps: | |
- name: Checkout Repository # Step needed to access the PR description using github CLI | |
uses: actions/checkout@eef61447b9ff4aafe5dcd4e0bbf5d482be7e7871 #v4.2.1 | |
- name: Set Branch Variables | |
id: set-branch-variables | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
github_event_inputs_powpeg_branch: ${{ github.event.inputs.powpeg-branch }} | |
github_event_inputs_rit_branch: ${{ github.event.inputs.rit-branch }} | |
github_event_name: ${{ github.event_name }} | |
github_event_pull_request_number: ${{ github.event.pull_request.number }} | |
github_head_ref: ${{ github.head_ref }} | |
github_ref_name: ${{ github.ref_name }} | |
github_event_pull_request_head_repo_owner_login: ${{ github.event.pull_request.head.repo.owner.login }} | |
github_repository_owner: ${{ github.repository_owner }} | |
run: | | |
PR_DESCRIPTION=pr-description.txt | |
ALLOWED_BRANCH_CHARACTERS='[-+./0-9A-Z_a-z]' | |
default_rskj_branch=master | |
default_powpeg_branch=master | |
default_rit_branch=main | |
get_branch_from_description() | |
{ | |
_prefix=$1 | |
# On lines matching "`$_prefix:...`", replace the lines with the | |
# thing in ... and print the result. | |
_search_re='\@`'$_prefix:$ALLOWED_BRANCH_CHARACTERS'\{1,\}`@' | |
_replace_re='s@.*`'$_prefix:'\('$ALLOWED_BRANCH_CHARACTERS'\{1,\}\)`.*@\1@p' | |
_branch=$(sed -n "$_search_re $_replace_re" "$PR_DESCRIPTION") | |
echo "$_branch" | |
} | |
is_valid_branch_name() | |
{ | |
echo "$1" | grep -qx "$ALLOWED_BRANCH_CHARACTERS\\{1,\\}" | |
} | |
if [ "$github_event_name" = workflow_dispatch ]; then | |
RSKJ_BRANCH=$github_ref_name | |
POWPEG_BRANCH=${github_event_inputs_powpeg_branch:-$default_powpeg_branch} | |
RIT_BRANCH=${github_event_inputs_rit_branch:-$default_rit_branch} | |
elif [ "$github_event_name" = pull_request ]; then | |
gh pr view "$github_event_pull_request_number" --json body -q .body >"$PR_DESCRIPTION" | |
RSKJ_BRANCH=$(get_branch_from_description rskj) | |
: ${RSKJ_BRANCH:=${github_head_ref:-$default_rskj_branch}} | |
POWPEG_BRANCH=$(get_branch_from_description fed) | |
: ${POWPEG_BRANCH:=$default_powpeg_branch} | |
RIT_BRANCH=$(get_branch_from_description rit) | |
: ${RIT_BRANCH:=$default_rit_branch} | |
else | |
RSKJ_BRANCH=$default_rskj_branch | |
POWPEG_BRANCH=$default_powpeg_branch | |
RIT_BRANCH=$default_rit_branch | |
fi | |
if ! is_valid_branch_name "$RSKJ_BRANCH"; then | |
echo "rskj: invalid branch name: $RSKJ_BRANCH" >&2 | |
exit 1 | |
fi | |
if ! is_valid_branch_name "$POWPEG_BRANCH"; then | |
echo "fed: invalid branch name: $POWPEG_BRANCH" >&2 | |
exit 1 | |
fi | |
if ! is_valid_branch_name "$RIT_BRANCH"; then | |
echo "rit: invalid branch name: $RIT_BRANCH" >&2 | |
exit 1 | |
fi | |
# Set the Repo Owner | |
REPO_OWNER="${github_event_pull_request_head_repo_owner_login:-$github_repository_owner}" | |
echo "REPO_OWNER=$REPO_OWNER" >> $GITHUB_ENV | |
echo "RSKJ_BRANCH=$RSKJ_BRANCH" >> $GITHUB_ENV | |
echo "RIT_BRANCH=$RIT_BRANCH" >> $GITHUB_ENV | |
echo "POWPEG_BRANCH=$POWPEG_BRANCH" >> $GITHUB_ENV | |
- name: Set Build URL | |
id: set-build-url | |
run: | | |
BUILD_URL="https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id }}" | |
echo "BUILD_URL=$BUILD_URL" >> $GITHUB_ENV | |
- name: Sanitize Github Variables | |
id: sanitize-github-variables | |
env: | |
GITHUB_EVENT_PULL_REQUEST_TITLE: ${{ github.event.pull_request.title }} | |
run: | | |
# Delete non-alphanumeric characters and limit to 75 chars which is the branch title limit in GitHub | |
SAFE_PULL_REQUEST_TITLE=$(echo "${GITHUB_EVENT_PULL_REQUEST_TITLE}" | tr -cd '[:alnum:]_ -' | cut -c1-75) | |
echo "SAFE_PULL_REQUEST_TITLE=$SAFE_PULL_REQUEST_TITLE" >> $GITHUB_ENV | |
- name: Run Rootstock Integration Tests | |
uses: rsksmart/rootstock-integration-tests@e86332474179a63f027d0fe969687d3d24f34c29 #v1 | |
with: | |
rskj-branch: ${{ env.RSKJ_BRANCH }} | |
powpeg-node-branch: ${{ env.POWPEG_BRANCH }} | |
rit-branch: ${{ env.RIT_BRANCH }} | |
repo-owner: ${{ env.REPO_OWNER }} | |
- name: Send Slack Notification on Success | |
if: success() && github.event.pull_request.head.repo.owner.login == 'rsksmart' | |
uses: slackapi/slack-github-action@37ebaef184d7626c5f204ab8d3baff4262dd30f0 # v1.27.0 | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.GHA_SLACK_NOTIFICATION_TOKEN }} | |
GITHUB_EVENT_PULL_REQUEST_HTML_URL: ${{ github.event.pull_request.html_url }} | |
with: | |
channel-id: ${{ vars.GHA_SLACK_NOTIFICATION_CHANNEL }} | |
payload: | | |
{ | |
"attachments": [ | |
{ | |
"color": "good", | |
"text": "*PASSED*: :white_check_mark: - *${{ env.SAFE_PULL_REQUEST_TITLE }}* \n*Pull request*: ${{ env.GITHUB_EVENT_PULL_REQUEST_HTML_URL }} \n*Pipeline*: ${{ env.BUILD_URL }} \n*Branches used*: [ rskj:`${{ env.RSKJ_BRANCH }}` ] [ fed:`${{ env.POWPEG_BRANCH }}` ] [ rit:`${{ env.RIT_BRANCH }}` ]" | |
} | |
] | |
} | |
- name: Send Slack Notification on Failure | |
if: failure() && github.event.pull_request.head.repo.owner.login == 'rsksmart' | |
uses: slackapi/slack-github-action@37ebaef184d7626c5f204ab8d3baff4262dd30f0 # v1.27.0 | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.GHA_SLACK_NOTIFICATION_TOKEN }} | |
GITHUB_EVENT_PULL_REQUEST_HTML_URL: ${{ github.event.pull_request.html_url }} | |
with: | |
channel-id: ${{ vars.GHA_SLACK_NOTIFICATION_CHANNEL }} | |
payload: | | |
{ | |
"attachments": [ | |
{ | |
"color": "danger", | |
"text": "*FAILED*: :x: - *${{ env.SAFE_PULL_REQUEST_TITLE }}* \n*Pull request*: ${{ env.GITHUB_EVENT_PULL_REQUEST_HTML_URL }} \n*Pipeline*: ${{ env.BUILD_URL }} \n*Branches used*: [ rskj:`${{ env.RSKJ_BRANCH }}` ] [ fed:`${{ env.POWPEG_BRANCH }}` ] [ rit:`${{ env.RIT_BRANCH }}` ]" | |
} | |
] | |
} |