
committed by
Harshavardhana

2 changed files with 99 additions and 13 deletions
@ -0,0 +1,83 @@ |
|||
/* |
|||
* Minio Cloud Storage, (C) 2016 Minio, Inc. |
|||
* |
|||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|||
* you may not use this file except in compliance with the License. |
|||
* You may obtain a copy of the License at |
|||
* |
|||
* http://www.apache.org/licenses/LICENSE-2.0
|
|||
* |
|||
* Unless required by applicable law or agreed to in writing, software |
|||
* distributed under the License is distributed on an "AS IS" BASIS, |
|||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|||
* See the License for the specific language governing permissions and |
|||
* limitations under the License. |
|||
*/ |
|||
|
|||
package cmd |
|||
|
|||
import ( |
|||
"fmt" |
|||
"net/http" |
|||
"net/http/httptest" |
|||
"testing" |
|||
"time" |
|||
) |
|||
|
|||
// This test sets globalMaxConn to 1 and starts 6 connections in
|
|||
// parallel on a server with the rate limit handler configured. This
|
|||
// should allow one request to execute at a time, and at most 4 to
|
|||
// wait to execute and the 6th request should get a 429 status code
|
|||
// error.
|
|||
func TestRateLimitHandler(t *testing.T) { |
|||
// save the global Max connections
|
|||
saveGlobalMaxConn := globalMaxConn |
|||
|
|||
globalMaxConn = 1 |
|||
testHandler := func(w http.ResponseWriter, r *http.Request) { |
|||
time.Sleep(100 * time.Millisecond) |
|||
fmt.Fprintln(w, "Hello client!") |
|||
} |
|||
rlh := setRateLimitHandler(http.HandlerFunc(testHandler)) |
|||
ts := httptest.NewServer(rlh) |
|||
respCh := make(chan int) |
|||
startTime := time.Now() |
|||
for i := 0; i < 6; i++ { |
|||
go func(ch chan<- int) { |
|||
resp, err := http.Get(ts.URL) |
|||
if err != nil { |
|||
t.Errorf( |
|||
"Got error requesting test server - %v\n", |
|||
err, |
|||
) |
|||
} |
|||
respCh <- resp.StatusCode |
|||
}(respCh) |
|||
} |
|||
|
|||
tooManyReqErrCount := 0 |
|||
for i := 0; i < 6; i++ { |
|||
code := <-respCh |
|||
if code == 429 { |
|||
tooManyReqErrCount++ |
|||
} else if code != 200 { |
|||
t.Errorf("Got non-200 resp code - %d\n", code) |
|||
} |
|||
} |
|||
duration := time.Since(startTime) |
|||
if duration < time.Duration(500*time.Millisecond) { |
|||
// as globalMaxConn is 1, only 1 request will execute
|
|||
// at a time, and the five allowed requested will take
|
|||
// at least 500 ms.
|
|||
t.Errorf("Expected all requests to take at least 500ms, but it was done in %v\n", |
|||
duration) |
|||
} |
|||
if tooManyReqErrCount != 1 { |
|||
t.Errorf("Expected to get 1 error, but got %d", |
|||
tooManyReqErrCount) |
|||
} |
|||
ts.Close() |
|||
|
|||
// restore the global Max connections
|
|||
globalMaxConn = saveGlobalMaxConn |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue