-
-
Notifications
You must be signed in to change notification settings - Fork 861
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
tests: fix win32 #3172
tests: fix win32 #3172
Conversation
coverage failed because this: Lines 127 to 134 in fa6dac8
|
I just use pytest's tmp_path to create a real file on disk. pytest will clean it up after test. |
tests/test_utils.py
Outdated
@@ -122,6 +123,7 @@ def test_logging_redirect_chain(server, caplog): | |||
] | |||
|
|||
|
|||
@pytest.mark.skipif(sys.platform == "win32", reason="os path sep escaped on windows") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We don't need this skipif
now, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we still need this skipif because path seprator /
is double escaped on this tests, don't know why....
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you remove the skipif
, so we can see the exact error in CI?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
E
E At index 1 diff: ('httpx', 10, "load_verify_locations cafile='C:\\\\Users\\\\Trim21\\\\proj\\\\httpx\\\\.venv\\\\Lib\\\\site-packages\\\\certifi\\\\cacert.pem'") != ('httpx', 10, "load_verify_locations cafile='C:\\Users\\Trim21\\proj\\httpx\\.venv\\Lib\\site-packages\\certifi\\cacert.pem'")
E
E Full diff:
E [
E (
E 'httpx',
E 10,
E 'load_ssl_context verify=True cert=None trust_env=True http2=False',
E ),
E (
E 'httpx',
E 10,
E 'load_verify_locations '
E - "cafile='C:\\Users\\Trim21\\proj\\httpx\\.venv\\Lib\\site-packages\\certifi\\cacert.pem'",
E + "cafile='C:\\\\Users\\\\Trim21\\\\proj\\\\httpx\\\\.venv\\\\Lib\\\\site-packages\\\\certifi\\\\cacert.pem'",
E ? ++ ++ ++ ++ ++ ++ ++ ++ ++
E ),
E ]
@pytest.mark.skipif( | ||
sys.platform == "win32", reason="time related tests are flaky on win32" | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I assume we could drop this, and this particular test would actually pass okay on windows?
(Also, I think we might want to raise a related refactoring issue to remove these /slow_response
tests completely.)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this test may pass on windows.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it's a time accuracy problem on windows. we could increase sleep time in /slow_response
to several seconds to fix this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm wrong about this, looks like increase sleep time in /slow_response won't help testing write timeout
@@ -32,3 +37,4 @@ jobs: | |||
run: "scripts/test" | |||
- name: "Enforce coverage" | |||
run: "scripts/coverage" | |||
if: "matrix.os == 'ubuntu'" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We probably don't need this conditional once we've fixed up all the tests to pass okay on windows, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
scritps/coverage only works on unix
|
||
strategy: | ||
matrix: | ||
os: ["ubuntu", "windows"] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure - I'm pleased to see us fix the test cases up for supporting windows, tho do we want to double the time our test runs take to complete?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with keeping it simple, and not add windows.
Summary
There are several test cases broken on windows.
Checklist