Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

broken test with reruns plugin #64

Open
phnmn opened this issue Oct 9, 2023 · 3 comments · May be fixed by #76
Open

broken test with reruns plugin #64

phnmn opened this issue Oct 9, 2023 · 3 comments · May be fixed by #76

Comments

@phnmn
Copy link

phnmn commented Oct 9, 2023

When test runs with reruns pytest plugin (eg pytest-rerunfailures) failed test will become broken with "already stored" error:

E               KeyError: "Internal Error - This fixture 'database' was already stored for test id 'test_rerun_harvets.py::test_database'"

example of test_rerun_harvets.py

import pytest
from pytest_harvest import saved_fixture

@pytest.fixture
@saved_fixture
def database():
    return "postgresql"


def test_database(database):
    assert database == "clickhouse"

and run test with 2 reruns

python -m pytest --reruns 2 test_rerun_harvets.py

installed deps:

decopatch==1.4.10
exceptiongroup==1.1.3
iniconfig==2.0.0
makefun==1.15.1
packaging==23.2
pluggy==1.3.0
pytest==7.4.2
pytest-harvest==1.10.4
pytest-rerunfailures==12.0
six==1.16.0
tomli==2.0.1
@smarie
Copy link
Owner

smarie commented Nov 29, 2023

Thanks @phnmn for reporting this issue !

I guess that pytest-rerunfailures does not change the test node id when re-running tests ?
Indeed we currently have a protection against the same node id trying to save data twice:

raise KeyError("Internal Error - This fixture '%s' was already "

Should we issue a warning and allow overwriting previous run's saved data ? This seems risky but maybe it is not, after all ?

@phnmn
Copy link
Author

phnmn commented Nov 29, 2023

@smarie, thank you for you response.
I can't figure out what case you want to avoid with this protection.
In my project I found a workaround for this by using a custom storage implementation.

class HarvestStoreMockDict(OrderedDict):
    def __contains__(self, item):
        return False

HARVEST_STORE = HarvestStoreMockDict()

@pytest.fixture(scope="session")
@saved_fixture(HARVEST_STORE)
def some_fixture():
    ...

And I didn't encounter any problems during this time.

@smarie
Copy link
Owner

smarie commented Nov 30, 2023

I can't figure out what case you want to avoid with this protection.

I think that this was more of a way for me to check that the storage logic was indeed creating a distinct slot for each test node.
Now that the plugin has been around for years, I know that this was the case :)

So we could remove the protection and instead overwrite the previously saved contents.
Would you like to propose a PR for this ?

@phnmn phnmn linked a pull request Nov 27, 2024 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants