Skip to content

Commit

Permalink
Merge remote-tracking branch 'richtja/mr_avocado'
Browse files Browse the repository at this point in the history
Signed-off-by: Cleber Rosa <[email protected]>
  • Loading branch information
clebergnu committed Feb 7, 2024
2 parents 50d320b + ebcb718 commit a87b81c
Showing 1 changed file with 97 additions and 2 deletions.
99 changes: 97 additions & 2 deletions action.yml
Original file line number Diff line number Diff line change
@@ -1,15 +1,20 @@
name: 'Avocado CI tools Collection'
description: 'Run avocado-framework specific actions for avocado projects on pull requests or issues to improve avocado-framework development.'
inputs:
# Python Project Configuration is expected to be in a pyproject.toml
avocado-static-checks:
description: |
Runs avocado-static-checks on pull requests.
Default is false.
default: false
avocado-project:
description: |
Mr. avocado configuration for manipulating with PR and issues.
Default is false.
default: false
runs:
using: "composite"
steps:
# --- avocado-static-checks ---
- if: ${{ inputs.avocado-static-checks == 'true' }}
uses: actions/checkout@v2
with:
Expand All @@ -20,4 +25,94 @@ runs:
pip3 install -r avocado-ci-tools/static-checks/requirements.txt
avocado-ci-tools/static-checks/run-static-checks
shell: bash

# --- avocado-project ---
- if: ${{ inputs.avocado-project == 'true' }}
name: Generate token
id: generate_token
uses: tibdex/github-app-token@021a2405c7f990db57f5eae5397423dcc554159c
with:
app_id: ${{ secrets.MR_AVOCADO_ID }}
installation_id: ${{ secrets.MR_AVOCADO_INSTALLATION_ID }}
private_key: ${{ secrets.MR_AVOCADO_PRIVATE_KEY }}
- if: ${{ inputs.avocado-project == 'true' }}
name: Get project data
env:
GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }}
ORGANIZATION: avocado-framework
PROJECT_NUMBER: 1
run: |
gh api graphql -f query='
query($org: String!, $number: Int!) {
organization(login: $org){
projectV2(number: $number) {
id
fields(first:20) {
nodes {
... on ProjectV2Field {
id
name
}
... on ProjectV2SingleSelectField {
id
name
options {
id
name
}
}
}
}
}
}
}' -f org=$ORGANIZATION -F number=$PROJECT_NUMBER > project_data.json
echo 'PROJECT_ID='$(jq '.data.organization.projectV2.id' project_data.json) >> $GITHUB_ENV
echo 'STATUS_FIELD_ID='$(jq '.data.organization.projectV2.fields.nodes[] | select(.name== "Status") | .id' project_data.json) >> $GITHUB_ENV
if [[ ${{ github.event_name }} == pull_request_target ]]; then
echo 'EVENT_ID='${{ github.event.pull_request.node_id }} >> $GITHUB_ENV
echo 'FIELD_VALUE='$(jq '.data.organization.projectV2.fields.nodes[] | select(.name== "Status") | .options[] | select(.name=="Review Requested") |.id' project_data.json) >> $GITHUB_ENV
else
echo 'EVENT_ID='${{ github.event.issue.node_id }} >> $GITHUB_ENV
echo 'FIELD_VALUE='$(jq '.data.organization.projectV2.fields.nodes[] | select(.name== "Status") | .options[] | select(.name=="Triage") |.id' project_data.json) >> $GITHUB_ENV
fi
shell: bash
- if: ${{ inputs.avocado-project == 'true' }}
name: Add Item to project
env:
GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }}
run: |
item_id="$( gh api graphql -f query='
mutation($project:ID!, $item:ID!) {
addProjectV2ItemById(input: {projectId: $project, contentId: $item}) {
item {
id
}
}
}' -f project=$PROJECT_ID -f item=$EVENT_ID --jq '.data.addProjectV2ItemById.item.id')"
echo 'ITEM_ID='$item_id >> $GITHUB_ENV
shell: bash
- if: ${{ inputs.avocado-project == 'true' }}
name: Set fields
env:
GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }}
run: |
gh api graphql -f query='
mutation (
$project: ID!
$item: ID!
$status_field: ID!
$status_value: String!
) {
set_status: updateProjectV2ItemFieldValue(input: {
projectId: $project
itemId: $item
fieldId: $status_field
value: {
singleSelectOptionId: $status_value
}
}) {
projectV2Item {
id
}
}
}' -f project=$PROJECT_ID -f item=$ITEM_ID -f status_field=$STATUS_FIELD_ID -f status_value=${{ env.FIELD_VALUE }} --silent
shell: bash

0 comments on commit a87b81c

Please sign in to comment.