-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #148 from NASA-AMMOS/release--v2.7.0
Release v2.7.0
- Loading branch information
Showing
11 changed files
with
159 additions
and
12 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 |
---|---|---|
@@ -1,4 +1,4 @@ | ||
DOCKER_TAG=v2.11.0 | ||
DOCKER_TAG=v2.18.0 | ||
REPOSITORY_DOCKER_URL=ghcr.io/nasa-ammos | ||
|
||
AERIE_USERNAME=aerie | ||
|
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
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
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
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
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
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
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
Binary file renamed
BIN
+10.3 MB
...ests/files/models/banananation-2.11.0.jar → ...ests/files/models/banananation-2.18.0.jar
Binary file not shown.
Binary file not shown.
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,106 @@ | ||
from typing import Dict | ||
import pytest | ||
import requests | ||
|
||
from aerie_cli.aerie_host import AerieHost, COMPATIBLE_AERIE_VERSIONS, AerieJWT | ||
|
||
|
||
class MockJWT: | ||
def __init__(self, *args, **kwargs): | ||
self.default_role = 'viewer' | ||
|
||
class MockResponse: | ||
def __init__(self, json: Dict, text: str = None, ok: bool = True) -> None: | ||
self.json_data = json | ||
self.text = text | ||
self.ok = ok | ||
|
||
def json(self) -> Dict: | ||
if self.json_data is None: | ||
raise requests.exceptions.JSONDecodeError("", "", 0) | ||
return self.json_data | ||
|
||
|
||
class MockSession: | ||
|
||
def __init__(self, mock_response: MockResponse) -> None: | ||
self.mock_response = mock_response | ||
|
||
def get(self, *args, **kwargs) -> MockResponse: | ||
return self.mock_response | ||
|
||
def post(self, *args, **kwargs) -> MockResponse: | ||
return self.mock_response | ||
|
||
|
||
def get_mock_aerie_host(json: Dict = None, text: str = None, ok: bool = True) -> AerieHost: | ||
mock_response = MockResponse(json, text, ok) | ||
mock_session = MockSession(mock_response) | ||
return AerieHost("", "", mock_session) | ||
|
||
|
||
def test_check_aerie_version(): | ||
aerie_host = get_mock_aerie_host( | ||
json={"version": COMPATIBLE_AERIE_VERSIONS[0]}) | ||
|
||
aerie_host.check_aerie_version() | ||
|
||
|
||
def test_authenticate_invalid_version(capsys, monkeypatch): | ||
ah = AerieHost("", "") | ||
|
||
def mock_get(*_, **__): | ||
return MockResponse({"version": "1.0.0"}) | ||
def mock_post(*_, **__): | ||
return MockResponse({"token": ""}) | ||
def mock_check_auth(*_, **__): | ||
return True | ||
|
||
monkeypatch.setattr(requests.Session, "get", mock_get) | ||
monkeypatch.setattr(requests.Session, "post", mock_post) | ||
monkeypatch.setattr(AerieHost, "check_auth", mock_check_auth) | ||
monkeypatch.setattr(AerieJWT, "__init__", MockJWT.__init__) | ||
|
||
with pytest.raises(RuntimeError) as e: | ||
ah.authenticate("") | ||
|
||
assert "Incompatible Aerie version: 1.0.0" in str(e.value) | ||
|
||
|
||
def test_authenticate_invalid_version_force(capsys, monkeypatch): | ||
ah = AerieHost("", "") | ||
|
||
def mock_get(*_, **__): | ||
return MockResponse({"version": "1.0.0"}) | ||
def mock_post(*_, **__): | ||
return MockResponse({"token": ""}) | ||
def mock_check_auth(*_, **__): | ||
return True | ||
|
||
monkeypatch.setattr(requests.Session, "get", mock_get) | ||
monkeypatch.setattr(requests.Session, "post", mock_post) | ||
monkeypatch.setattr(AerieHost, "check_auth", mock_check_auth) | ||
monkeypatch.setattr(AerieJWT, "__init__", MockJWT.__init__) | ||
|
||
ah.authenticate("", force=True) | ||
|
||
assert capsys.readouterr().out == "Warning: Incompatible Aerie version: 1.0.0\n" | ||
|
||
|
||
def test_no_version_endpoint(): | ||
aerie_host = get_mock_aerie_host(text="blah Aerie Gateway blah", ok=True) | ||
|
||
with pytest.raises(RuntimeError) as e: | ||
aerie_host.check_aerie_version() | ||
|
||
assert "Incompatible Aerie version: host version unknown" in str(e.value) | ||
|
||
|
||
def test_version_broken_gateway(): | ||
aerie_host = get_mock_aerie_host( | ||
text="502 Bad Gateway or something", ok=True) | ||
|
||
with pytest.raises(RuntimeError) as e: | ||
aerie_host.check_aerie_version() | ||
|
||
assert "Bad response from Aerie Gateway" in str(e.value) |