Skip to content

Fix flakiness in the autoscaler stat server tests #1758

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

Merged
merged 1 commit into from
Aug 10, 2018

Conversation

dprotaso
Copy link
Member

I changed the point when the test server address is notified.

Prior this was done before calling http.Server::Serve.

Because of this if http.Server::Shutdown finished before
http.Server::Serve started - Serve would block indefinitely

Now we notify the server address when net.Listener::Accept is
invoked by the http.Server. This required tweaking how TCP
keep alives are set on the connection

Fixes #1738

Ran go test -v -count=100000 -run TestServerLifecycle

I changed the point when the test server address is notified.

Prior this was done before calling http.Server::Serve.

Because of this if http.Server::Shutdown finished before
http.Server::Serve started - Serve would block indefinitely

Now we notify the server address when net.Listener::Accept is
invoked by the http.Server. This required tweaking how TCP
keep alives are set on the connection
@google-prow-robot
Copy link

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: dprotaso
To fully approve this pull request, please assign additional approvers.
We suggest the following additional approver: josephburnett

If they are not already assigned, you can assign the PR to them by writing /assign @josephburnett in a comment when ready.

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@google-prow-robot google-prow-robot added the size/M Denotes a PR that changes 30-99 lines, ignoring generated files. label Jul 30, 2018
@knative-metrics-robot
Copy link

The following is the coverage report on pkg/.
Say /test pull-knative-serving-go-coverage to run the coverage report again

File Old Coverage New Coverage Delta
pkg/autoscaler/statserver/server.go Do not exist 78.1%

@dprotaso
Copy link
Member Author

glyn is vacation for a week

/assign @josephburnett

Copy link
Contributor

@glyn glyn left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@knative-prow-robot knative-prow-robot added the lgtm Indicates that a PR is ready to be merged. label Aug 6, 2018
Copy link
Contributor

@josephburnett josephburnett left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm
/approve

@knative-prow-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: dprotaso, glyn, josephburnett

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@knative-prow-robot knative-prow-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Aug 10, 2018
@knative-prow-robot knative-prow-robot merged commit ae2f722 into knative:master Aug 10, 2018
@dprotaso dprotaso deleted the fix-statserver-test branch September 11, 2018 23:15
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. lgtm Indicates that a PR is ready to be merged. size/M Denotes a PR that changes 30-99 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants