feat: Add comprehensive tests and ensure Go 1.22.2 compatibility #5
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This commit introduces a significant number of improvements to the ab-proxy tool:
Go Version Compatibility:
go.mod
to specifygo 1.22.2
.go.sum
was updated.Refactoring for Testability:
ab-proxy.go
was refactored.runBenchmark
function.Options
,Stats
,ErrorCollector
), making the code more modular and testable.Unit Tests:
ab_proxy_test.go
.ErrorCollector
functionality.Integration Tests:
mockservers_test.go
) to simulate real-world scenarios.ab_proxy_integration_test.go
.ab-proxy
as a subprocess and verify its behavior against the mock servers, covering:--show-errors
.Dockerization for Testing:
Dockerfile
that creates a containerized environment with Go 1.22.2.These changes enhance the reliability and maintainability of
ab-proxy
by providing a strong testing foundation and ensuring compatibility with an updated Go version.