Skip to content

Commit

Permalink
Windows installer, reorganize workflows
Browse files Browse the repository at this point in the history
  • Loading branch information
infeeeee committed Mar 27, 2023
1 parent b3834ed commit 7194a33
Show file tree
Hide file tree
Showing 10 changed files with 127 additions and 40 deletions.
28 changes: 28 additions & 0 deletions .github/workflows/build-exe.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
on:
workflow_call:

name: Workflow - Build exe

jobs:
build:
runs-on: windows-latest
name: Build Windows exe

steps:
- uses: actions/checkout@v3
name: Checkout
- uses: actions/setup-python@v4
name: Setup Python
with:
python-version: ${{ vars.PYTHON_VERSION}}
- name: Install deps
run: |
python -m pip install --upgrade pip
pip install .[build]
- name: Build
run: pyinstaller dyn2py.spec
- uses: actions/upload-artifact@v3
name: Upload artifact
with:
name: dyn2py.exe
path: dist/dyn2py.exe
35 changes: 35 additions & 0 deletions .github/workflows/build-installer.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
on:
workflow_call:

name: Workflow - Build installer

jobs:
build-installer:
runs-on: windows-latest
name: Build Windows installer

steps:
- uses: actions/checkout@v3
name: Checkout
- name: Install Inno Setup
run: |
Invoke-WebRequest -Uri https://jrsoftware.org/download.php/is.exe -OutFile is.exe
.\is.exe /verysilent
- name: Download artifact
uses: actions/download-artifact@v3
with:
name: dyn2py.exe
path: dist/dyn2py.exe
- name: Update version number
run: |
$regex = Select-String -Path pyproject.toml -Pattern '^version = "((?:\d\.){2}\d)"$'
$version = $regex.Matches.Groups[1].Value
(Get-Content dyn2py-installer.iss).Replace("x.x.x",$version) | Set-Content dyn2py-installer.iss
- name: Build installer
run: |
& "C:\Program Files (x86)\Inno Setup 6\ISCC.exe" -Qp $(Join-Path $PWD.Path dyn2py-installer.iss)
- uses: actions/upload-artifact@v3
name: Upload artifact
with:
name: dyn2py-installer.exe
path: Output/dyn2py-installer.exe
49 changes: 23 additions & 26 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,39 +10,29 @@ permissions:

jobs:
test:
name: Test
strategy:
matrix:
os: [ubuntu-latest, windows-latest]
uses: ./.github/workflows/test.yml
with:
python-version: ${{ vars.PYTHON_VERSION}}
python-version: ${{ vars.PYTHON_VERSION }}
os: ${{ matrix.os }}

build:
runs-on: windows-latest
build-exe:
name: Build Windows exe
needs: test
steps:
- uses: actions/checkout@v3
name: Checkout
- uses: actions/setup-python@v4
name: Setup Python
with:
python-version: ${{ vars.PYTHON_VERSION}}
- name: Install deps
run: |
python -m pip install --upgrade pip
pip install .[build]
- name: Build
run: pyinstaller dyn2py.spec
- uses: actions/upload-artifact@v3
name: Upload artifact
with:
name: dyn2py.exe
path: dist/dyn2py.exe
uses: ./.github/workflows/build-exe.yml

build-installer:
name: Build Windows installer
needs: build-exe
uses: ./.github/workflows/build-installer.yml

release:
name: Create Github release
runs-on: ubuntu-latest
needs: build
needs: build-installer
steps:
- uses: actions/checkout@v3
name: Checkout
Expand All @@ -51,17 +41,24 @@ jobs:
uses: metcalfc/[email protected]
with:
myToken: ${{ secrets.GITHUB_TOKEN }}
- name: Download artifact
- name: Download exe
uses: actions/download-artifact@v3
with:
name: dyn2py.exe
- name: Download installer
uses: actions/download-artifact@v3
with:
name: dyn2py-installer.exe
- name: Release
uses: softprops/action-gh-release@v1
with:
files: dyn2py.exe
body: ${{ steps.modified.outputs.log }}
files: |
dyn2py.exe
dyn2py-installer.exe
body: ${{ steps.changelog.outputs.changelog }}

pip:
name: Publish to PyPI
runs-on: ubuntu-latest
needs: release
steps:
Expand All @@ -70,7 +67,7 @@ jobs:
- uses: actions/setup-python@v4
name: Setup Python
with:
python-version: ${{ vars.PYTHON_VERSION}}
python-version: ${{ vars.PYTHON_VERSION }}
- name: Install deps
run: |
python -m pip install --upgrade pip
Expand Down
8 changes: 6 additions & 2 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,15 @@ on:
required: true
type: string

name: Workflow - Test

jobs:
test:
name: Run tests
runs-on: ${{ inputs.os }}
steps:
- uses: actions/checkout@v3
name: Checkout
- name: Set up Python ${{ inputs.python-version }}
uses: actions/setup-python@v4
with:
Expand All @@ -21,5 +25,5 @@ jobs:
run: |
python -m pip install --upgrade pip
pip install .
- name: Test
run: python -m unittest discover -v -s ./tests -p "test_*.py"
- name: Run tests
run: python -m unittest discover -v -s ./tests -p "test_*.py"
1 change: 1 addition & 0 deletions .github/workflows/unittests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ permissions:

jobs:
tests:
name: Unit tests
strategy:
matrix:
os: [ubuntu-latest, windows-latest]
Expand Down
14 changes: 9 additions & 5 deletions .github/workflows/website.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ on:
branches:
- main

# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:

# security: restrict permissions for CI jobs.
Expand All @@ -18,26 +17,30 @@ concurrency:
cancel-in-progress: true

jobs:
# Build the documentation and upload the static HTML files as an artifact.
build:
name: Build documentation
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
name: Checkout
- uses: actions/setup-python@v4
name: Setup Python
with:
python-version: "3.11"

python-version: ${{ vars.PYTHON_VERSION }}
- run: pip install -e .[doc]
name: Install deps
- run: pdoc -d google -o docs dyn2py

name: Generate docs
- uses: actions/upload-pages-artifact@v1
name: Upload artifact
with:
path: docs/

# Deploy the artifact to GitHub pages.
# This is a separate job so that only actions/deploy-pages has the necessary permissions.
deploy:
needs: build
name: Publish documentation
runs-on: ubuntu-latest
permissions:
pages: write
Expand All @@ -47,4 +50,5 @@ jobs:
url: ${{ steps.deployment.outputs.page_url }}
steps:
- id: deployment
name: Deploy page
uses: actions/deploy-pages@v1
17 changes: 17 additions & 0 deletions .github/workflows/windows-build.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
name: Build Windows exe and installer

on:
workflow_dispatch:
pull_request:
branches: ["main"]
# push:

jobs:
build-exe:
uses: ./.github/workflows/build-exe.yml
name: Build Windows exe

build-installer:
name: Build Windows installer
needs: build-exe
uses: ./.github/workflows/build-installer.yml
11 changes: 6 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
[![GitHub Release Date](https://img.shields.io/github/release-date/infeeeee/dyn2py?style=flat-square)](https://github.com/infeeeee/dyn2py/releases/latest)
[![GitHub last commit (branch)](https://img.shields.io/github/last-commit/infeeeee/dyn2py/main?style=flat-square)](https://github.com/infeeeee/dyn2py/commits/main)
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/infeeeee/dyn2py/unittests.yml?label=tests&style=flat-square)](https://github.com/infeeeee/dyn2py/actions/workflows/unittests.yml)
![GitHub top language](https://img.shields.io/github/languages/top/infeeeee/dyn2py?style=flat-square)
[![GitHub](https://img.shields.io/github/license/infeeeee/dyn2py?style=flat-square)](https://github.com/infeeeee/dyn2py/blob/main/LICENSE)

# dyn2py
Expand All @@ -17,14 +16,16 @@ Use cases:

## Installation

### Windows portable
### Windows portable and installer

Prebuilt exe available from github releases.
Prebuilt portable exe and installer available from github releases.

No requirements, just download `dyn2py.exe` from release assets:
No requirements, just download `dyn2py.exe` or `dyn2py-installer.exe` from release assets:

https://github.com/infeeeee/dyn2py/releases/latest

Installer automatically adds the install folder to the path, so simply `dyn2py` can be called from anywhere.

### With pip

For usage as a module or as a command line program
Expand Down Expand Up @@ -178,8 +179,8 @@ pyinstaller dyn2py.spec

### Create installer for Windows

- The already built exe should be in `dist\dyn2py.exe`
- Install Inno Setup: https://jrsoftware.org/isdl.php
- The already built exe should be in `dist\dyn2py.exe`
- Run this in powershell:

```powershell
Expand Down
2 changes: 1 addition & 1 deletion TODO.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
- [x] Tests on Windows
- [x] Windows Build
- [x] Pip
- [x] Windows Installer

## Documentation

Expand All @@ -25,6 +26,5 @@

## Extra features maybe later

- [ ] Windows Installer
- [ ] Autocomplete
- [ ] Winget
2 changes: 1 addition & 1 deletion dyn2py-installer.iss
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ ChangesEnvironment=yes
Name: "english"; MessagesFile: "compiler:Default.isl"

[Files]
Source: "dist\dyn2py.exe"; DestDir: "{app}"; Flags: ignoreversion
Source: "dist\dyn2py.exe"; DestDir: "{app}"; Flags: ignoreversion external


[Code]
Expand Down

0 comments on commit 7194a33

Please sign in to comment.