Compare commits
9 Commits
e1eade237c
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
cf2c07899c
|
|||
|
5be98f04c1
|
|||
|
38c65df769
|
|||
|
e12b1ffe3e
|
|||
|
93b1dfef79
|
|||
|
8c32b74838
|
|||
|
437a285cc8
|
|||
|
19fd94a675
|
|||
|
42a613279d
|
@@ -8,13 +8,12 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
runs-on: ubuntu-latest
|
runs-on: x86_64
|
||||||
|
container: golang:1.26
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- name: Checkout
|
||||||
|
run: |
|
||||||
- uses: actions/setup-go@v5
|
git clone --depth=1 --branch="${GITHUB_REF_NAME}" "${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git" .
|
||||||
with:
|
|
||||||
go-version-file: go.mod
|
|
||||||
|
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: go test -v -race -coverprofile=coverage.out ./...
|
run: go test -v -race -coverprofile=coverage.out ./...
|
||||||
|
|||||||
47
README.md
Normal file
47
README.md
Normal file
@@ -0,0 +1,47 @@
|
|||||||
|
# go-http-server
|
||||||
|
|
||||||
|
A minimal TCP-based HTTP server in Go for learning and experimentation. It demonstrates manual request-line and header parsing and simple connection handling.
|
||||||
|
|
||||||
|
Requires
|
||||||
|
- Go 1.26 or newer.
|
||||||
|
|
||||||
|
Quick start
|
||||||
|
1. Build
|
||||||
|
- cd into the project root (the directory that contains `go-http-server`) and run:
|
||||||
|
```
|
||||||
|
cd go-http-server
|
||||||
|
go build -o go-http-server
|
||||||
|
```
|
||||||
|
2. Run
|
||||||
|
- Start the server:
|
||||||
|
```
|
||||||
|
./go-http-server
|
||||||
|
```
|
||||||
|
- Or during development:
|
||||||
|
```
|
||||||
|
go run .
|
||||||
|
```
|
||||||
|
|
||||||
|
Testing
|
||||||
|
- Run unit tests:
|
||||||
|
```
|
||||||
|
cd go-http-server
|
||||||
|
go test ./...
|
||||||
|
```
|
||||||
|
|
||||||
|
What’s in the repo
|
||||||
|
- `main.go` — listener and connection lifecycle.
|
||||||
|
- `readheaders.go` — `readHeaders` and `parseRequestLine` logic; returns a `Headers` struct.
|
||||||
|
- `response_helper` — helpers for writing responses.
|
||||||
|
- `config` — runtime configuration (listen address, profiling toggle).
|
||||||
|
|
||||||
|
Notes
|
||||||
|
- The parser expects a request-line with exactly three tokens: `METHOD URI PROTO`.
|
||||||
|
- Header lines without a colon are ignored; values are trimmed.
|
||||||
|
- The server supports simple keep-alive behavior when the `Connection: keep-alive` header is present.
|
||||||
|
|
||||||
|
Contributing
|
||||||
|
- Open issues or PRs. Add tests for parsing or new behavior and run `go test ./...` before submitting.
|
||||||
|
|
||||||
|
License
|
||||||
|
- MIT
|
||||||
Reference in New Issue
Block a user