Skip to content

Commit

Permalink
Empty path (#395)
Browse files Browse the repository at this point in the history
* fix handling of empty path in tests
  • Loading branch information
DmitriyMusatkin authored Oct 31, 2022
1 parent dcbc111 commit e80c70d
Show file tree
Hide file tree
Showing 6 changed files with 33 additions and 20 deletions.
31 changes: 16 additions & 15 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -155,21 +155,22 @@ jobs:
python3 -c "from urllib.request import urlretrieve; urlretrieve('${{ env.BUILDER_HOST }}/${{ env.BUILDER_SOURCE }}/${{ env.BUILDER_VERSION }}/builder.pyz?run=${{ env.RUN }}', 'builder.pyz')"
python3 builder.pyz build -p aws-c-http --cmake-extra=-DENABLE_LOCALHOST_INTEGRATION_TESTS=ON
localhost-test-mac:
runs-on: macos-11 # latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Configure local host
run: |
python3 -m pip install h2
cd ./tests/py_localhost/
python3 server.py &
python3 non_tls_server.py &
- name: Build and test
run: |
python3 -c "from urllib.request import urlretrieve; urlretrieve('${{ env.BUILDER_HOST }}/${{ env.BUILDER_SOURCE }}/${{ env.BUILDER_VERSION }}/builder.pyz?run=${{ env.RUN }}', 'builder.pyz')"
python3 builder.pyz build -p aws-c-http --cmake-extra=-DENABLE_LOCALHOST_INTEGRATION_TESTS=ON
# localhost tests are flaky on mac. disable for now, put fixing it in backlog
# localhost-test-mac:
# runs-on: macos-11 # latest
# steps:
# - name: Checkout
# uses: actions/checkout@v3
# - name: Configure local host
# run: |
# python3 -m pip install h2
# cd ./tests/py_localhost/
# python3 server.py &
# python3 non_tls_server.py &
# - name: Build and test
# run: |
# python3 -c "from urllib.request import urlretrieve; urlretrieve('${{ env.BUILDER_HOST }}/${{ env.BUILDER_SOURCE }}/${{ env.BUILDER_VERSION }}/builder.pyz?run=${{ env.RUN }}', 'builder.pyz')"
# python3 builder.pyz build -p aws-c-http --cmake-extra=-DENABLE_LOCALHOST_INTEGRATION_TESTS=ON

localhost-test-win:
runs-on: windows-2022 # latest
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ Release
*#
*.iml
tags
.vscode

#vim swap file
*.swp
Expand Down
7 changes: 6 additions & 1 deletion bin/elasticurl/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -404,7 +404,12 @@ static struct aws_http_message *s_build_http_request(
}

aws_http_message_set_request_method(request, aws_byte_cursor_from_c_str(app_ctx->verb));
aws_http_message_set_request_path(request, app_ctx->uri.path_and_query);
if (app_ctx->uri.path_and_query.len != 0) {
aws_http_message_set_request_path(request, app_ctx->uri.path_and_query);
} else {
aws_http_message_set_request_path(request, aws_byte_cursor_from_c_str("/"));
}

if (protocol_version == AWS_HTTP_VERSION_2) {
struct aws_http_headers *h2_headers = aws_http_message_get_headers(request);
aws_http2_headers_set_request_scheme(h2_headers, app_ctx->uri.scheme);
Expand Down
2 changes: 1 addition & 1 deletion source/request_response.c
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ bool aws_http_header_name_eq(struct aws_byte_cursor name_a, struct aws_byte_curs
}

/**
* -- Datastructure Notes --
* -- Data Structure Notes --
* Headers are stored in a linear array, rather than a hash-table of arrays.
* The linear array was simpler to implement and may be faster due to having fewer allocations.
* The API has been designed so we can swap out the implementation later if desired.
Expand Down
2 changes: 1 addition & 1 deletion tests/test_localhost_integ.c
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ static int s_tester_init(struct tester *tester, struct aws_allocator *allocator,
.keep_alive_interval_sec = 0,
};
struct aws_http_connection_monitoring_options monitor_opt = {
.allowable_throughput_failure_interval_seconds = 1,
.allowable_throughput_failure_interval_seconds = 2,
.minimum_throughput_bytes_per_second = 1000,
};
struct aws_http_client_connection_options client_options = {
Expand Down
10 changes: 8 additions & 2 deletions tests/test_stream_manager.c
Original file line number Diff line number Diff line change
Expand Up @@ -530,6 +530,12 @@ static int s_sm_stream_acquiring_customize_request(
return AWS_OP_SUCCESS;
}

static struct aws_byte_cursor s_default_empty_path = AWS_BYTE_CUR_INIT_FROM_STRING_LITERAL("/");

struct aws_byte_cursor s_normalize_path(struct aws_byte_cursor path) {
return path.len == 0 ? s_default_empty_path : path;
}

static int s_sm_stream_acquiring(int num_streams) {
struct aws_http_message *request = aws_http2_message_new_request(s_tester.allocator);
ASSERT_NOT_NULL(request);
Expand All @@ -542,7 +548,7 @@ static int s_sm_stream_acquiring(int num_streams) {
},
{
.name = aws_byte_cursor_from_c_str(":path"),
.value = *aws_uri_path(&s_tester.endpoint),
.value = s_normalize_path(*aws_uri_path(&s_tester.endpoint)),
},
{
.name = aws_byte_cursor_from_c_str(":authority"),
Expand Down Expand Up @@ -1351,7 +1357,7 @@ static int s_sm_stream_acquiring_with_body(int num_streams) {
},
{
.name = aws_byte_cursor_from_c_str(":path"),
.value = *aws_uri_path(&s_tester.endpoint),
.value = s_normalize_path(*aws_uri_path(&s_tester.endpoint)),
},
{
.name = aws_byte_cursor_from_c_str(":authority"),
Expand Down

0 comments on commit e80c70d

Please sign in to comment.