-
Notifications
You must be signed in to change notification settings - Fork 264
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
Fix tests which incorporate network requests #368
Comments
TL;DR Testing against real (not mock) backends is essential. We can change the xfails() if you want. Perhaps @pytest.mark.xfails requires a bit of explanation...
Given that our code is not yet Python 3 compatible, we give query_server running on Python 3 an xfail on most test cases. We remove those xfails in #343 When we are running the tests on Travis CI we assume the network is working (or we never would have gotten to travis-ci.org in the first place). We test against the real search engines I believe is the right way to go. Mock payloads are no substitute for end-to-end tests that can alert the contributor to page misnumber issues, missing descriptions, Unicode characters, and captcha alerts. Last but not least in the instance where we are running the tests on our local machines. I open two terminals in one I run query-server locally and in the other I run the tests. If they pass, pytest prints a capital X and if they fail, pytest prints a lowercase x. If I forget to start the local server then I get a lowercase x. |
i would like to take up this issue. can i ? @cclauss @AnshulMalik |
@starlord1311 I think we still need to decide what the ToDo is before we start creating PRs. Let's first see how @AnshulMalik replies to my comment. Unless you already know what you want to do. You might look at the tests in #297 and see of any of them should be a PR of their own. |
I see a point in using data from actual network requests, since the parameters we are using to scrape the results might change, and we won't know it if we are testing on hard coded code. Can we have both solution? |
That sounds like a workable approach. @pytest.mark.xfail(not TRAVIS_CI, reason="Avoid network costs for local testing") could be put above all tests that use the network so that they would run in Travis CI but would fail without halting the testing when doing local testing. Local users who have a query-server running will see these end-to-end tests pass. The new tests which are created around mock data should include data that includes Unicode characters so that we can ensure Python2 is doing the right thing. @starlord1311 Do you want to create some test around mock data? |
@cclauss can you explain what i am supposed to do? |
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
mojeek.py. parsijoo.py, quora.py, yahoo.py, youtube.py (fossasia#368)
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
mojeek.py. parsijoo.py, quora.py, yahoo.py, youtube.py (fossasia#368)
Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml
mojeek.py. parsijoo.py, quora.py, yahoo.py, youtube.py (fossasia#368)
* Added unit test for server.py (#368) Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml * Readded the showlocals option for pytest in .travis.yml * Added unit tests for ask.py (#368) * Added unit test for server.py (#368) Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml * Added unit tests for ask.py (#368) * Added unit tests for baidu.py, bing.py, duckduckgo.py, google.py mojeek.py. parsijoo.py, quora.py, yahoo.py, youtube.py (#368) * Disabled unit tests for yandex * Added unit test for server.py (#368) Added dependency on mock in requirement.txt Updated server.py to use absolute imports Changed the invocation of server.py to 'python -m app.server' in .travis.yml * Added unit tests for ask.py (#368) * Added unit tests for baidu.py, bing.py, duckduckgo.py, google.py mojeek.py. parsijoo.py, quora.py, yahoo.py, youtube.py (#368) * Disabled unit tests for yandex * Replaced raise AssertionError calls with assert statements * Added unit tests for generalized.py and added bandit.yml (#368)
Current behavior:
Currently, while testing, here, we actually fetch data from search engines.
This is not what we want, since network is unreliable. So our tests will also be unreliable, one test fails and second time another test fails.
Expected behavior:
We should provide custom input to the functions which parse the response, assuming response is available
The text was updated successfully, but these errors were encountered: