-
-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This adds the beginnings of a test suite, and the related infrastructure to run the test suite using tox and GitHub actions.
- Loading branch information
1 parent
c3cbccc
commit 56ba9a8
Showing
6 changed files
with
143 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
name: CI | ||
on: | ||
push: | ||
branches: master | ||
pull_request: | ||
jobs: | ||
test: | ||
runs-on: ubuntu-latest | ||
name: Test (Python ${{ matrix.python-version }}) | ||
strategy: | ||
matrix: | ||
python-version: ["3.8", "3.9", "3.10", "3.11", "3.12"] | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- name: Set up Python | ||
uses: actions/setup-python@v4 | ||
with: | ||
python-version: "${{ matrix.python-version }}" | ||
- name: Install tox | ||
run: | | ||
python -m pip install --upgrade pip | ||
pip install tox tox-gh-actions | ||
- name: Run tests | ||
run: tox | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,3 +2,4 @@ __pycache__ | |
dist | ||
build | ||
jellyfin_apiclient_python.egg-info | ||
.tox |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
import unittest | ||
|
||
from jellyfin_apiclient_python.credentials import Credentials | ||
|
||
|
||
class TestCredientials(unittest.TestCase): | ||
def setUp(self): | ||
self.credentials = Credentials() | ||
|
||
def assertEmptyCredentials(self, credentials): | ||
empty_creds = {"Servers": []} | ||
self.assertEqual(credentials, empty_creds) | ||
|
||
def test_set_credentials_and_get_credentials(self): | ||
credentials = {"Server": "Foo"} | ||
self.credentials.set_credentials(credentials) | ||
self.assertEqual(self.credentials.get_credentials(), credentials) | ||
|
||
def test_get_credentials(self): | ||
empty = self.credentials.get_credentials() | ||
self.assertEmptyCredentials(empty) | ||
|
||
def test_set_credentials_evals_to_false(self): | ||
self.credentials.set_credentials(False) | ||
# get() then swallows the ValueError, and returns empty credentials, | ||
# but only if self.credentials evaluates to False | ||
self.assertEmptyCredentials(self.credentials.get()) | ||
|
||
def test_get(self): | ||
empty = self.credentials.get() | ||
self.assertEmptyCredentials(empty) | ||
|
||
def test_set(self): | ||
data = {"User": "foobar"} | ||
self.credentials.set(data) | ||
self.assertEqual(self.credentials.get(), data) | ||
# Passing anything that evaluates to false will clear it | ||
self.credentials.set(False) | ||
self.assertEmptyCredentials(self.credentials.get()) | ||
|
||
def test_add_update_user(self): | ||
server = {} | ||
user_data = {"Id": 42} | ||
self.credentials.add_update_user(server, user_data) | ||
self.assertEqual(server, {"Users": [user_data]}) | ||
# If we re-add the same user, it is unchanged. | ||
self.credentials.add_update_user(server, user_data) | ||
self.assertEqual(server, {"Users": [user_data]}) | ||
|
||
def test_add_update_server_no_id(self): | ||
with self.assertRaises(KeyError): | ||
self.credentials.add_update_server({}, {"Foo": "Bar"}) | ||
|
||
def test_add_update_server_adds_datelastaccessed(self): | ||
servers = [] | ||
server = {"Id": 42} | ||
new_server = self.credentials.add_update_server(servers, server) | ||
server["DateLastAccessed"] = "2001-01-01T00:00:00Z" | ||
self.assertEqual(new_server, server) | ||
|
||
def test_add_update_server_merges_data(self): | ||
# DateLastAccessed must be older for merges to happen | ||
servers = [{"Id": 42, "DateLastAccessed": "1999-12-31T23:58:59Z"}] | ||
server = { | ||
"Id": 42, "AccessToken": "xx", "UserId": 1, "UserLinkType": "Foo", | ||
"ExchangeToken": "Bar", "ManualAddress": 2, "LocalAddress": 3, | ||
"Name": "Test", "LastConnectionMode": "Unknown", | ||
"ConnectServerId": 44 | ||
} | ||
new_server = self.credentials.add_update_server(servers, server) | ||
self.assertEqual(new_server, server) | ||
|
||
def test_add_update_server_does_not_merge_if_newer(self): | ||
servers = [{"Id": 42, "DateLastAccessed": "2023-10-01T01:02:03Z"}] | ||
server = {"Id": 42} | ||
new_server = self.credentials.add_update_server(servers, server) | ||
self.assertEqual(new_server, servers[0]) | ||
|
||
def test_add_update_server_does_not_merge_unknown_fields(self): | ||
servers = [{"Id": 42, "DateLastAccessed": "1999-12-31T23:58:59Z"}] | ||
server = {"Id": 42, "Foo": "Bar"} | ||
new_server = self.credentials.add_update_server(servers, server) | ||
merged_server = {"Id": 42, "DateLastAccessed": "2001-01-01T00:00:00Z"} | ||
self.assertEqual(new_server, merged_server) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
[tox] | ||
envlist = | ||
lint, | ||
py{38,39,310,311,312}, | ||
|
||
[gh-actions] | ||
python = | ||
3.8: py38 | ||
3.9: py39 | ||
3.10: py310, lint | ||
3.11: py311 | ||
3.12: py312 | ||
|
||
[testenv] | ||
deps = | ||
pytest | ||
commands = pytest {posargs} | ||
|
||
[testenv:lint] | ||
basepython = python3.10 | ||
skip_install = true | ||
deps = | ||
ruff | ||
commands = | ||
ruff check --exit-non-zero-on-fix jellyfin_apiclient_python tests |