-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
SNOW-1636849 Auto-teardown Native App in integration tests (#1478)
Changes `with project_directory()` to `with nativeapp_project_directory()`, which automatically runs `snow app teardown` before exiting the project. This allows us to remove the `try`/`finally` in most tests. For tests that were using `with pushd(test_project)`, this has been changed to `with nativeapp_teardown()`, which is what `with nativeapp_project_directory()` uses under the hood.
- Loading branch information
1 parent
784936c
commit 9c81c52
Showing
13 changed files
with
498 additions
and
772 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,63 @@ | ||
from __future__ import annotations | ||
|
||
from contextlib import contextmanager | ||
from pathlib import Path | ||
from typing import Any | ||
|
||
import pytest | ||
|
||
from tests_integration.conftest import SnowCLIRunner | ||
|
||
|
||
@pytest.fixture | ||
def nativeapp_project_directory(project_directory, nativeapp_teardown): | ||
"""Wrapper around the project_directory fixture specific to Native App testing. | ||
This fixture provides a context manager that does the following: | ||
- Automatically calls `snow app teardown` before exiting | ||
Parameters for the returned context manager: | ||
:param name: The name of the directory in tests_integration/test_data/projects to use. | ||
""" | ||
|
||
@contextmanager | ||
def _nativeapp_project_directory(name): | ||
with project_directory(name) as d: | ||
with nativeapp_teardown(project_dir=d): | ||
yield d | ||
|
||
return _nativeapp_project_directory | ||
|
||
|
||
@pytest.fixture | ||
def nativeapp_teardown(runner: SnowCLIRunner): | ||
"""Runs `snow app teardown` before exiting. | ||
This fixture provides a context manager that runs | ||
`snow app teardown --force --cascade` before exiting, | ||
regardless of any exceptions raised. | ||
Parameters for the returned context manager: | ||
:param project_dir: Path to the project directory (optional) | ||
:param env: Environment variables to replace os.environ (optional) | ||
""" | ||
|
||
@contextmanager | ||
def _nativeapp_teardown( | ||
*, | ||
project_dir: Path | None = None, | ||
env: dict | None = None, | ||
): | ||
try: | ||
yield | ||
finally: | ||
args = ["--force", "--cascade"] | ||
if project_dir: | ||
args += ["--project", str(project_dir)] | ||
kwargs: dict[str, Any] = {} | ||
if env: | ||
kwargs["env"] = env | ||
result = runner.invoke_with_connection(["app", "teardown", *args], **kwargs) | ||
assert result.exit_code == 0 | ||
|
||
return _nativeapp_teardown |
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
Oops, something went wrong.