Skip to content

Commit

Permalink
add python
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewsy-opal committed Nov 26, 2024
1 parent c1f691f commit d164fc3
Show file tree
Hide file tree
Showing 9 changed files with 85 additions and 46 deletions.
89 changes: 60 additions & 29 deletions .github/workflows/autogen-remote-changes.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,61 +4,92 @@ name: Auto-Update SDK
# schedule:
# - cron: "0 0 * * 1" # Runs every Monday at midnight
# workflow_dispatch: # Allows manual triggering of the workflow

on: [push, pull_request]
on: [push]

jobs:
update-sdk:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ["3.12"]
steps:
- name: Checkout repository
- uses: actions/checkout@v3
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: '18'
- name: Install OpenAPI Generator CLI
run: npm install @openapitools/openapi-generator-cli -g
- name: Install dependencies
run: |
git clone https://github.com/${{ github.repository }} repo
cd repo
git config --global user.name "github-actions[bot]"
git config --global user.email "github-actions[bot]@users.noreply.github.com"
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Pull and generate SDK
run: |
cd repo
make gen-openapi-remote
run: make gen-openapi-remote-for-ci
- name: Check for changes
id: check_changes
run: |
cd repo
if git diff --quiet; then
echo "changes=false" >> $GITHUB_ENV
else
echo "changes=true" >> $GITHUB_ENV
fi
- name: Set up Git
if: env.changes == 'true'
run: |
git config user.name "github-actions[bot]"
git config user.email "github-actions[bot]@users.noreply.github.com"
- name: Commit changes
if: env.changes == 'true'
run: |
cd repo
git checkout -b auto-update-sdk || git checkout auto-update-sdk
BRANCH_NAME="auto-update-sdk-$(date +'%Y-%m-%d-%H-%M-%S')"
echo "BRANCH_NAME=$BRANCH_NAME" >> $GITHUB_ENV
git checkout -b $BRANCH_NAME || git checkout $BRANCH_NAME
git add .
git commit -m "Auto-update SDK on $(date +'%Y-%m-%d')"
- name: Push changes
if: env.changes == 'true'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: git push --force --set-upstream origin $BRANCH_NAME
- name: Install GitHub CLI
if: env.changes == 'true'
run: |
cd repo
git push --force --set-upstream origin auto-update-sdk
- name: Create a pull request
sudo apt-get update
sudo apt-get install -y gh
- name: Check for existing pull request
if: env.changes == 'true'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
id: check_pr
run: |
PR_EXISTS=$(gh pr list --search "Auto-update SDK" --base main --state open --json number -q '.[0].number')
if [[ -n "$PR_EXISTS" ]]; then
echo "pr_exists=true" >> $GITHUB_ENV
echo "PR_NUMBER=$PR_EXISTS" >> $GITHUB_ENV
else
echo "pr_exists=false" >> $GITHUB_ENV
fi
- name: Create a pull request
if: env.changes == 'true' && env.pr_exists == 'false'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: |
PR_TITLE="Auto-update SDK on $(date +'%Y-%m-%d')"
PR_BODY="This pull request was automatically created by GitHub Actions to update the SDK."
curl -H "Authorization: token $GITHUB_TOKEN" \
-X POST \
-H "Content-Type: application/json" \
-d @- \
https://api.github.com/repos/${{ github.repository }}/pulls <<EOF
{
"title": "$PR_TITLE",
"body": "$PR_BODY",
"head": "auto-update-sdk",
"base": "main"
}
EOF
PR_BODY="This pull request was automatically created by GitHub Actions to update the SDK with the latest remote OpenAPI specification."
gh pr create --title "$PR_TITLE" --body "$PR_BODY" --head $BRANCH_NAME --base main
- name: Update existing pull request
if: env.changes == 'true' && env.pr_exists == 'true'
run: |
echo "An existing pull request titled 'Auto-update SDK' is already open. Updating it with the latest changes."
# Push the changes to the existing branch to update the pull request
git push --set-upstream origin $BRANCH_NAME --force
# Add a comment to the existing pull request to notify about the update
gh pr comment $PR_NUMBER --body "This pull request has been updated with the latest changes from the automated SDK update process on $(date +'%Y-%m-%d %H:%M:%S')."
2 changes: 1 addition & 1 deletion .github/workflows/python.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"]
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12"]

steps:
- uses: actions/checkout@v3
Expand Down
3 changes: 0 additions & 3 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,6 @@ stages:
- pip install -r test-requirements.txt
- pytest --cov=opal

pytest-3.7:
extends: .pytest
image: python:3.7-alpine
pytest-3.8:
extends: .pytest
image: python:3.8-alpine
Expand Down
2 changes: 1 addition & 1 deletion .openapi-generator/templates/github-workflow.mustache
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ jobs:
runs-on: ubuntu-latest
strategy:
matrix:
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"]
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11", "3.12"]

steps:
- uses: actions/checkout@v3
Expand Down
1 change: 0 additions & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
# ref: https://docs.travis-ci.com/user/languages/python
language: python
python:
- "3.7"
- "3.8"
- "3.9"
- "3.10"
Expand Down
9 changes: 7 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,14 @@ SHELL:=/bin/bash
PYTHON_POST_PROCESS_FILE=python -m black

OPENAPI_GEN=openapi-generator generate --enable-post-process-file -i api/openapi.yaml -g python -o . -c config.json -t .openapi-generator/templates
OPENAPI_GEN_CI=openapi-generator-cli generate --enable-post-process-file -i api/openapi.yaml -g python -o . -c config.json -t .openapi-generator/templates
PULL_REMOTE_OPENAPI=curl https://app.opal.dev/openapi.yaml > api/openapi.yaml

gen-openapi:
$(OPENAPI_GEN)
gen-openapi-remote:
curl https://app.opal.dev/openapi.yaml > api/openapi.yaml
$(OPENAPI_GEN)
$(PULL_REMOTE_OPENAPI)
$(OPENAPI_GEN)
gen-openapi-remote-for-ci:
$(PULL_REMOTE_OPENAPI)
$(OPENAPI_GEN_CI)
9 changes: 8 additions & 1 deletion config.json
Original file line number Diff line number Diff line change
@@ -1 +1,8 @@
{"enumClassPrefix": true, "packageName": "opal", "gitHost": "github.com", "gitUserId": "opalsecurity", "gitRepoId": "opal-python", "disallowAdditionalPropertiesIfNotPresent":false}
{
"enumClassPrefix": true,
"packageName": "opal",
"gitHost": "github.com",
"gitUserId": "opalsecurity",
"gitRepoId": "opal-python",
"disallowAdditionalPropertiesIfNotPresent": false
}
5 changes: 2 additions & 3 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
urllib3 >= 1.25.3, < 2.1.0
setuptools >= 21.0.0
python_dateutil >= 2.5.3
urllib3 >= 1.25.3, < 3.0.0
python_dateutil >= 2.8.2
pydantic >= 2
typing-extensions >= 4.7.1
11 changes: 6 additions & 5 deletions test-requirements.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
pytest~=7.1.3
pytest-cov>=2.8.1
pytest-randomly>=3.12.0
mypy>=1.4.1
types-python-dateutil>=2.8.19
pytest >= 7.2.1
pytest-cov >= 2.8.1
tox >= 3.9.0
flake8 >= 4.0.0
types-python-dateutil >= 2.8.19.14
mypy >= 1.5

0 comments on commit d164fc3

Please sign in to comment.