Skip to content

Backlog Limits Checker #103593

Backlog Limits Checker

Backlog Limits Checker #103593

---
name: Backlog Limits Checker
on:
#[push]
schedule:
- cron: '*/10 * * * *'
jobs:
check_suse_qa_c_backlog_limits:
runs-on: ubuntu-latest
steps:
- name: checkout repo content
uses: actions/checkout@v2
with:
persist-credentials: false
fetch-depth: 0
- name: setup python
uses: actions/setup-python@v2
with:
python-version: 3.8
- name: install python packages
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: prepare output md file
run: |
rm -f index.md
touch index.md
python backlog_checker.py init
- name: General description
if: always()
run: |
python backlog_checker.py description
env:
text: |
This is the dashboard for Quality Engineering for Containers and Public Cloud.
We are currently working on four projects: Containers, JeOS, WSL, Public Cloud and SLE Micro
* [General team overview](#general_team_overview)
* [Bugs vs Features Backlog Length](#bugs_vs_features_backlog_length)
* [Incoming vs outcoming during the last 30 days](#incoming_vs_outcoming_during_the_last_30_days)
* [Incoming vs outcoming during the last 4 months](#incoming_vs_outcoming_during_the_last_4_months)
* [Backlog Lengths by priority](#backlog_lengths_by_priority)
* [Pickup time alerts](#pickup_time_alerts)
* [Non updated tickets for 15 days](#non_updated_tickets_for_15_days)
* [Tickets in progress with no changes in 15 days](#tickets_in_progress_with_no_changes_in_15_days)
* [Tickets with the status Blocked and Feedback with no changes in 15 days](#tickets_with_the_status_blocked_and_feedback_with_no_changes_in_15_days)
* [No Changes in 15 Days (Blocked and Feedback)](#no_changes_in_15_days_blocked_and_feedback)
* [Abnormalities](#abnormalities)
* [In Progress But Not Assigned](#in_progress_but_not_assigned)
* [Assigned but not started](#assigned_but_not_started)
* [New tickets](#new_tickets)
* [Coordination without subtasks](#coordination_without_subtasks)
* [Epics](#epics)
######################################################################
# General team overview
######################################################################
# Bugs vs Features Backlog Length
- name: Bugs vs Features Backlog Length Containers
if: always()
run: |
python backlog_checker.py comp2 tb_start
env:
category: "General team overview"
header: "Bugs vs Features Backlog Length"
header_description: |
This table compares the number of bugs against the planned tickets.
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Containers"
query1: "Backlog Bugs Length: Containers"
query2: "Backlog Features Length: Containers"
query3: "Backlog Length: Containers"
head1: "Bugs"
head2: "Features"
head3: "Total"
- name: Bugs vs Features Backlog Length JeOS
if: always()
run: |
python backlog_checker.py comp2
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "JeOS"
query1: "Backlog Bugs Length: JeOS"
query2: "Backlog Features Length: JeOS"
query3: "Backlog Length: JeOS"
head1: "Bugs"
head2: "Features"
head3: "Total"
- name: Bugs vs Features Backlog Length WSL
if: always()
run: |
python backlog_checker.py comp2
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "WSL"
query1: "Backlog Bugs Length: WSL"
query2: "Backlog Features Length: WSL"
query3: "Backlog Length: WSL"
head1: "Bugs"
head2: "Features"
head3: "Total"
- name: Bugs vs Features Backlog Length Public Cloud
if: always()
run: |
python backlog_checker.py comp2
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Public Cloud"
query1: "Backlog Bugs Length: Public Cloud"
query2: "Backlog Features Length: Public Cloud"
query3: "Backlog Length: Public Cloud"
head1: "Bugs"
head2: "Features"
head3: "Total"
- name: Bugs vs Features Backlog Length SLE Micro
if: always()
run: |
python backlog_checker.py comp2 tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "SLE Micro"
query1: "Backlog Bugs Length: SLE Micro"
query2: "Backlog Features Length: SLE Micro"
query3: "Backlog Length: SLE Micro"
head1: "Bugs"
head2: "Features"
head3: "Total"
# Incoming vs outcoming during the last 30 days
- name: Input vs Output ratios in 30 days Containers
if: always()
run: |
python backlog_checker.py comp tb_start
env:
header: "Incoming vs outcoming during the last 30 days"
header_description: |
This table shows the balance between ticket creation and ticket resolution.
If more tickets arrive than we are capable of solving,
it means that the length of the backlog will grow, and therefore we need more work force in that project.
And more tickets come out than come in, so we can divert workforce to other projects if necessary.
Two time ranges are contemplated, short-term (30 days) and medium-term (4 months)
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Containers"
query1: "Created In The Last 30 Days: Containers"
query2: "Finished In The Last 30 Days: Containers"
query3: "Backlog Length: Containers"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 30 days JeOS
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "JeOS"
query1: "Created In The Last 30 Days: JeOS"
query2: "Finished In The Last 30 Days: JeOS"
query3: "Backlog Length: JeOS"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 30 days WSL
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "WSL"
query1: "Created In The Last 30 Days: WSL"
query2: "Finished In The Last 30 Days: WSL"
query3: "Backlog Length: WSL"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 30 days Public Cloud
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Public Cloud"
query1: "Created In The Last 30 Days: Public Cloud"
query2: "Finished In The Last 30 Days: Public Cloud"
query3: "Backlog Length: Public Cloud"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 30 days SLE Micro
if: always()
run: |
python backlog_checker.py comp tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "SLE Micro"
query1: "Created In The Last 30 Days: SLE Micro"
query2: "Finished In The Last 30 Days: SLE Micro"
query3: "Backlog Length: SLE Micro"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
# Incoming vs outcoming during the last 4 months
- name: Input vs Output ratios in 4 months Containers
if: always()
run: |
python backlog_checker.py comp tb_start
env:
header: "Incoming vs outcoming during the last 4 months"
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Containers"
query1: "Created In The Last 120 Days: Containers"
query2: "Finished In The Last 120 Days: Containers"
query3: "Backlog Length: Containers"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 4 months JeOS
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "JeOS"
query1: "Created In The Last 120 Days: JeOS"
query2: "Finished In The Last 120 Days: JeOS"
query3: "Backlog Length: JeOS"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 4 months WSL
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "WSL"
query1: "Created In The Last 120 Days: WSL"
query2: "Finished In The Last 120 Days: WSL"
query3: "Backlog Length: WSL"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 4 months Public Cloud
if: always()
run: |
python backlog_checker.py comp
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "Public Cloud"
query1: "Created In The Last 120 Days: Public Cloud"
query2: "Finished In The Last 120 Days: Public Cloud"
query3: "Backlog Length: Public Cloud"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
- name: Input vs Output ratios in 4 months SLE Micro
if: always()
run: |
python backlog_checker.py comp tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
rowText: "SLE Micro"
query1: "Created In The Last 120 Days: SLE Micro"
query2: "Finished In The Last 120 Days: SLE Micro"
query3: "Backlog Length: SLE Micro"
head1: "New tickets"
head2: "Finished tickets"
head3: "Backlog length"
######################################################################
# Backlog lengths
######################################################################
# Backlog lengths : Containers
- name: check urgent priority containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority Length: Containers"
header: "Containers"
category: "Backlog Lengths by priority"
category_description: |
These tables show the backlog length per priority. The "Warning level" is a the max number of tickets that we consider safe. This level is established by consensus in the team.
max_level: 1
- name: check high priority containers backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority Length: Containers"
max_level: 3
- name: check normal priority containers backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority Length: Containers"
max_level: 20
# Backlog lengths : JeOS
- name: check urgent priority JeOS backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority Length: JeOS"
header: "JeOS"
max_level: 1
- name: check high priority JeOS backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority Length: JeOS"
max_level: 3
- name: check normal priority JeOS backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority Length: JeOS"
max_level: 20
# Backlog lengths : WSL
- name: check urgent priority WSL backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority Length: WSL"
header: "WSL"
max_level: 1
- name: check high priority WSL backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority Length: WSL"
max_level: 3
- name: check normal priority WSL backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority Length: WSL"
max_level: 20
# Backlog lengths : SLE Micro
- name: check urgent priority SLE Micro backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority Length: SLE Micro"
header: "SLE Micro"
max_level: 1
- name: check high priority SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority Length: SLE Micro"
max_level: 3
- name: check normal priority SLE Micro backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority Length: SLE Micro"
max_level: 20
# Backlog lengths : Public Cloud
- name: check urgent priority Public Cloud backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority Length: Public Cloud"
header: "Public Cloud"
max_level: 1
- name: check high priority Public Cloud backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority Length: Public Cloud"
max_level: 3
- name: check normal priority Public Cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority Length: Public Cloud"
max_level: 20
######################################################################
# Pickup timeouts
######################################################################
# Urgent prioities timeout
- name: check urgent priority containers backlog timeout
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority: Containers"
category: "Pickup time alerts"
category_description: |
These tables show the tickets that are in violation of the [SLO](https://progress.opensuse.org/projects/openqatests/wiki#SLOs-service-level-objectives)
header: "Urgent Priority"
hideMaxLevel: "1"
- name: check urgent priority jeos backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority: JeOS"
hideMaxLevel: "1"
- name: check urgent priority SLE Micro backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority: SLE Micro"
hideMaxLevel: "1"
- name: check urgent priority wsl backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority: WSL"
hideMaxLevel: "1"
- name: check urgent priority public cloud backlog timeout
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Urgent Priority: Public Cloud"
hideMaxLevel: "1"
# High prioities timeout
- name: check high priority containers backlog timeout
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority: Containers"
header: "High Priority"
hideMaxLevel: "1"
- name: check high priority jeos backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority: JeOS"
hideMaxLevel: "1"
- name: check high priority SLE Micro backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority: SLE Micro"
hideMaxLevel: "1"
- name: check high priority wsl backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority: WSL"
hideMaxLevel: "1"
- name: check high priority public cloud backlog timeout
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "High Priority: Public Cloud"
hideMaxLevel: "1"
# Normal prioities timeout
- name: check normal priority containers backlog timeout
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority: Containers"
header: "Normal Priority"
hideMaxLevel: "1"
- name: check normal priority jeos backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority: JeOS"
hideMaxLevel: "1"
- name: check normal priority SLE Micro backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority: SLE Micro"
hideMaxLevel: "1"
- name: check normal priority wsl backlog timeout
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority: WSL"
hideMaxLevel: "1"
- name: check normal priority public cloud backlog timeout
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Normal Priority: Public Cloud"
hideMaxLevel: "1"
######################################################################
# No changes in 15 days
######################################################################
# No Changes in 15 days
- name: check not changed in 15 days containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: Containers"
category: "Non updated tickets for 15 days"
category_description: |
These tables show the tickets that have more than 15 days without any update
header: "Tickets in progress with no changes in 15 days"
header_description: |
These tickets are in progress and we should review that because maybe have blockers or are under feedback and we forgot to update the status of the ticket.
hideMaxLevel: "1"
- name: check not changed in 15 days jeos backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: JeOS"
hideMaxLevel: "1"
- name: check not changed in 15 days SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: SLE Micro"
hideMaxLevel: "1"
- name: check not changed in 15 days wsl backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: WSL"
hideMaxLevel: "1"
- name: check not changed in 15 days public cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: Public Cloud"
hideMaxLevel: "1"
# No changes in 15 days (Blocked and Feedback)
- name: check not changed in 15 days containers backlog length (Blocked and Feedback)
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: Containers (Blocked and Feedback)"
header: "Tickets with the status Blocked and Feedback with no changes in 15 days"
header_description: |
These tickets are in progress and we should review that because maybe what is blocking is solved. Or we need to insist when we don't have feedback.
hideMaxLevel: "1"
- name: check not changed in 15 days jeos backlog length (Blocked and Feedback)
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: JeOS (Blocked and Feedback)"
hideMaxLevel: "1"
- name: check not changed in 15 days SLE Micro backlog length (Blocked and Feedback)
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: SLE Micro (Blocked and Feedback)"
hideMaxLevel: "1"
- name: check not changed in 15 days wsl backlog length (Blocked and Feedback)
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: WSL (Blocked and Feedback)"
hideMaxLevel: "1"
- name: check not changed in 15 days public cloud backlog length (Blocked and Feedback)
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Changed: Public Cloud (Blocked and Feedback)"
hideMaxLevel: "1"
######################################################################
# Abnormalities
######################################################################
# In progress but not Assigned
- name: check in progress not assigned containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Assigned: Containers"
category: "Abnormalities"
category_description: |
These tickets has some kind of abnormality, and should be alerted to the team and reviewed
header: "In Progress But Not Assigned"
header_description: |
These are the typical tickets that due to forgetfulness are in progress but there is no assigned person.
If there is any clarification to be made with the person who is working with it, we need to know his name
hideMaxLevel: "1"
- name: check in progress not assigned jeos backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Assigned: JeOS"
hideMaxLevel: "1"
- name: check in progress not assigned SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Assigned: SLE Micro"
hideMaxLevel: "1"
- name: check in progress not assigned wsl backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Assigned: WSL"
hideMaxLevel: "1"
- name: check in progress not assigned cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Not Assigned: Public Cloud"
hideMaxLevel: "1"
# Assigned but not started
- name: check in progress assigned but not started containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Assigned but not started: Containers"
header: "Assigned but not started"
header_description: |
Some tickets could be blocked by a teammate for a time assigned to him but not started. This option is considered,
but care must be taken if too much time has passed or if the person is on sick leave or on vacation.
This would mean that the task is effectively blocked
hideMaxLevel: "1"
- name: check in progress assigned but not started jeos backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Assigned but not started: JeOS"
hideMaxLevel: "1"
- name: check in progress assigned but not started SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Assigned but not started: SLE Micro"
hideMaxLevel: "1"
- name: check in progress assigned but not started wsl backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Assigned but not started: WSL"
hideMaxLevel: "1"
- name: check in progress assigned but not started public cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Assigned but not started: Public Cloud"
hideMaxLevel: "1"
# New tickets
- name: check new containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "New: Containers"
header: "New tickets"
header_description: |
New tickets that are not workable and need clarification should be reviewed during the refinement meeting.
hideMaxLevel: "1"
failIcon: "review"
passIcon: ""
- name: check new jeos backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "New: JeOS"
hideMaxLevel: "1"
failIcon: "review"
passIcon: ""
- name: check new SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "New: SLE Micro"
hideMaxLevel: "1"
failIcon: "review"
passIcon: ""
- name: check new wsl backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "New: WSL"
hideMaxLevel: "1"
failIcon: "review"
passIcon: ""
- name: check new public cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "New: Public Cloud"
hideMaxLevel: "1"
failIcon: "review"
passIcon: ""
# Coordination without subtasks
- name: check in progress coordination without subtasks containers backlog length
if: always()
run: |
python backlog_checker.py tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Coordination with no subtasks: Containers"
header: "Coordination without subtasks"
header_description: |
Epics can be defined to record a new line of work in a project.
Initially these epics may not have tasks assigned to them. This table is a reminder for the PO
hideMaxLevel: "1"
- name: check in progress coordination without subtasks jeos backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Coordination with no subtasks: JeOS"
hideMaxLevel: "1"
- name: check in progress coordination without subtasks SLE Micro backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Coordination with no subtasks: SLE Micro"
hideMaxLevel: "1"
- name: check in progress coordination without subtasks wsl backlog length
if: always()
run: |
python backlog_checker.py
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Coordination with no subtasks: WSL"
hideMaxLevel: "1"
- name: check in progress coordination without subtasks public cloud backlog length
if: always()
run: |
python backlog_checker.py tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Coordination with no subtasks: Public Cloud"
hideMaxLevel: "1"
# Epics
- name: check container epics
if: always()
run: |
python backlog_checker.py epic
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Epics Containers"
category: "Epics"
header: "Container Epics"
- name: check jeos epics
if: always()
run: |
python backlog_checker.py epic
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Epics JeOS"
header: "JeOS Epics"
- name: check SLE Micro epics
if: always()
run: |
python backlog_checker.py epic
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Epics SLE Micro"
header: "SLE Micro Epics"
- name: check wsl epics
if: always()
run: |
python backlog_checker.py epic
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Epics WSL"
header: "WSL Epics"
- name: check public cloud epics
if: always()
run: |
python backlog_checker.py epic
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Epics Public Cloud"
header: "Public Cloud Epics"
# Aging
- name: aging containers
if: always()
run: |
python backlog_checker.py aging tb_start
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Finished In The Last 30 Days: Containers"
header: "Aging tickets finished in the last 30 days"
category: "Aging of tickets"
category_description: |
Mesures the time since the ticket is created and the ticket is resolved
rowText: "Containers"
head: "Days to complete"
- name: aging JeOS
if: always()
run: |
python backlog_checker.py aging
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Finished In The Last 30 Days: JeOS"
rowText: "JeOS"
head: "Days to complete"
- name: aging WSL
if: always()
run: |
python backlog_checker.py aging
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Finished In The Last 30 Days: WSL"
rowText: "WSL"
head: "Days to complete"
- name: aging Public Cloud
if: always()
run: |
python backlog_checker.py aging
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Finished In The Last 30 Days: Public Cloud"
rowText: "Public Cloud"
head: "Days to complete"
- name: aging SLE Micro
if: always()
run: |
python backlog_checker.py aging tb_end
env:
key: ${{ secrets.REDMINE_API_KEY }}
query: "Finished In The Last 30 Days: SLE Micro"
rowText: "SLE Micro"
head: "Days to complete"
- name: Footer
if: always()
run: |
python backlog_checker.py description
env:
text: |
# Other links
**Finished tickets this week**
* [Containers](https://progress.opensuse.org/projects/containers/issues?utf8=%E2%9C%93&set_filter=1&sort=priority%3Adesc%2Cid%3Adesc&f%5B%5D=closed_on&op%5Bclosed_on%5D=w&f%5B%5D=&c%5B%5D=subject&c%5B%5D=project&c%5B%5D=status&c%5B%5D=priority&c%5B%5D=author&c%5B%5D=assigned_to&c%5B%5D=relations&c%5B%5D=parent&c%5B%5D=tags_relations&c%5B%5D=updated_on&group_by=status&t%5B%5D=)
* [JeOS](https://progress.opensuse.org/projects/jeos/issues?utf8=%E2%9C%93&set_filter=1&sort=priority%3Adesc%2Cid%3Adesc&f%5B%5D=closed_on&op%5Bclosed_on%5D=w&f%5B%5D=&c%5B%5D=subject&c%5B%5D=project&c%5B%5D=status&c%5B%5D=priority&c%5B%5D=author&c%5B%5D=assigned_to&c%5B%5D=relations&c%5B%5D=parent&c%5B%5D=tags_relations&c%5B%5D=updated_on&group_by=status&t%5B%5D=)
* [WSL](https://progress.opensuse.org/projects/wsl/issues?utf8=%E2%9C%93&set_filter=1&sort=priority%3Adesc%2Cid%3Adesc&f%5B%5D=closed_on&op%5Bclosed_on%5D=w&f%5B%5D=&c%5B%5D=subject&c%5B%5D=project&c%5B%5D=status&c%5B%5D=priority&c%5B%5D=author&c%5B%5D=assigned_to&c%5B%5D=relations&c%5B%5D=parent&c%5B%5D=tags_relations&c%5B%5D=updated_on&group_by=status&t%5B%5D=)
* [Public Cloud](https://progress.opensuse.org/projects/public_cloud/issues?utf8=%E2%9C%93&set_filter=1&sort=priority%3Adesc%2Cid%3Adesc&f%5B%5D=closed_on&op%5Bclosed_on%5D=w&f%5B%5D=&c%5B%5D=subject&c%5B%5D=project&c%5B%5D=status&c%5B%5D=priority&c%5B%5D=author&c%5B%5D=assigned_to&c%5B%5D=relations&c%5B%5D=parent&c%5B%5D=tags_relations&c%5B%5D=updated_on&group_by=status&t%5B%5D=)
* [SLE Micro](https://progress.opensuse.org/projects/microos_slemicro/issues?utf8=%E2%9C%93&set_filter=1&sort=priority%3Adesc%2Cid%3Adesc&f%5B%5D=closed_on&op%5Bclosed_on%5D=w&f%5B%5D=&c%5B%5D=subject&c%5B%5D=project&c%5B%5D=status&c%5B%5D=priority&c%5B%5D=author&c%5B%5D=assigned_to&c%5B%5D=relations&c%5B%5D=parent&c%5B%5D=tags_relations&c%5B%5D=updated_on&group_by=status&t%5B%5D=)
# Commit
- name: Commit files
if: always()
run: |
rm -f README.md
mv index.md README.md
git config --local user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
git add README.md
git commit --amend --no-edit
- name: Push changes
if: always()
uses: ad-m/github-push-action@master
with:
force: true
github_token: ${{ secrets.GITHUB_TOKEN }}
branch: ${{ github.ref }}