6
0
mirror of https://github.com/ChristianLight/tutor.git synced 2025-02-14 14:43:42 +00:00

Merge remote-tracking branch 'origin/master' into nightly

This commit is contained in:
Overhang.IO 2022-11-29 14:58:08 +00:00
commit 9466fc395b
5 changed files with 38 additions and 21 deletions

View File

@ -20,13 +20,16 @@ jobs:
# https://github.com/actions/runner-images#available-images
- os: ubuntu-latest
locale: C.UTF-8
gh_os: linux
# https://endoflife.date/macos
- os: macos-latest
locale: en_US.UTF-8
gh_os: macOs
env:
LC_ALL: ${{ matrix.locale }}
LANG: ${{ matrix.locale }}
steps:
##### Setup environment
# https://github.com/actions/checkout
- uses: actions/checkout@v3
- name: Set up Python
@ -42,26 +45,26 @@ jobs:
run: make ci-info
- name: Install requirements
run: make bootstrap-dev-plugins
##### Run tests, generate bundle
- name: Run tests
run: make test
- name: Create bundle
run: make bundle
- name: Test bundle
run: make ci-test-bundle
##### Download gh utility: https://github.com/cli/cli/releases
- name: Check for presence of "gh" CLI utility
run: echo "gh_bin=$(which gh)" >> $GITHUB_ENV
- name: Download gh utility (linux)
- name: Download gh utility
run: |
curl -L -o gh.tar.gz https://github.com/cli/cli/releases/download/v2.20.2/gh_2.20.2_linux_amd64.tar.gz
curl -L -o gh.tar.gz https://github.com/cli/cli/releases/download/v2.20.2/gh_2.20.2_${{ matrix.gh_os }}_amd64.tar.gz
tar xzf gh.tar.gz
echo "gh_bin=./gh_2.20.2_linux_amd64/bin/gh" >> $GITHUB_ENV
if: ${{ env.gh_bin == '' && !contains(matrix.os, 'macos') }}
- name: Download gh utility (macos)
run: |
curl -L -o gh.tar.gz https://github.com/cli/cli/releases/download/v2.20.2/gh_2.20.2_macOS_amd64.tar.gz
tar xzf gh.tar.gz
echo "gh_bin=./gh_2.20.2_macOS_amd64/bin/gh" >> $GITHUB_ENV
if: ${{ env.gh_bin == '' && contains(matrix.os, 'macos') }}
echo "gh_bin=./gh_2.20.2_${{ matrix.gh_os }}_amd64/bin/gh" >> $GITHUB_ENV
if: ${{ env.gh_bin == '' }}
##### Create release on GitHub
- name: Create or update GitHub release
# I wish there was an `--update` option to the `gh release create` command, but
# there isn't.
@ -71,8 +74,12 @@ jobs:
export GH_ARGS="${{ github.ref }} --notes-file=release_description.md"
echo "gh args: '$GH_ARGS"
${{ env.gh_bin }} release create $GH_ARGS || ${{ env.gh_bin }} release edit $GH_ARGS
env:
GH_TOKEN: ${{ github.token }}
- name: Upload release asset to GitHub
run: |
export FILENAME="tutor-$(uname -s)_$(uname -m)"
mv ./dist/tutor $FILENAME
${{ env.gh_bin }} release upload --clobber ${{ github.ref }} $FILENAME
env:
GH_TOKEN: ${{ github.token }}

View File

@ -8,7 +8,7 @@ jobs:
sync:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Add remote

View File

@ -10,9 +10,9 @@ jobs:
tests:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v2
uses: actions/setup-python@v3
with:
python-version: 3.9
- name: Upgrade pip

View File

@ -32,7 +32,8 @@ class TestCommandMixin:
"TUTOR_ROOT": root,
"TUTOR_IGNORE_ENTRYPOINT_PLUGINS": "1",
"TUTOR_IGNORE_DICT_PLUGINS": "1",
}
},
mix_stderr=False,
)
return runner.invoke(
cli, args, obj=TestContext(root), catch_exceptions=catch_exceptions

View File

@ -70,8 +70,17 @@ class UtilsTests(unittest.TestCase):
self.assertIsNotNone(imported.q)
def test_is_root(self) -> None:
result = utils.is_root()
self.assertFalse(result)
with patch("sys.platform", "win32"):
with patch.object(utils, "get_user_id", return_value=42):
self.assertFalse(utils.is_root())
with patch.object(utils, "get_user_id", return_value=0):
self.assertFalse(utils.is_root())
with patch("sys.platform", "linux"):
with patch.object(utils, "get_user_id", return_value=42):
self.assertFalse(utils.is_root())
with patch.object(utils, "get_user_id", return_value=0):
self.assertTrue(utils.is_root())
@patch("sys.platform", "win32")
def test_is_root_win32(self) -> None:
@ -79,11 +88,11 @@ class UtilsTests(unittest.TestCase):
self.assertFalse(result)
def test_get_user_id(self) -> None:
result = utils.get_user_id()
if sys.platform == "win32":
self.assertEqual(0, result)
else:
self.assertNotEqual(0, result)
with patch("os.getuid", return_value=42):
self.assertEqual(42, utils.get_user_id())
with patch("sys.platform", new="win32"):
self.assertEqual(0, utils.get_user_id())
@patch("sys.platform", "win32")
def test_get_user_id_win32(self) -> None: