From 6d2a895db38d6989fa264b34b2deeae47435ca0c Mon Sep 17 00:00:00 2001 From: Leonid Bugaev Date: Thu, 3 Sep 2015 21:50:32 +0300 Subject: [PATCH] Fix file input replay speed --- Makefile | 2 +- input_file.go | 15 +++++++++------ 2 files changed, 10 insertions(+), 7 deletions(-) diff --git a/Makefile b/Makefile index d44977db..6c79473e 100644 --- a/Makefile +++ b/Makefile @@ -44,7 +44,7 @@ drun: docker run -v `pwd`:$(SOURCE_PATH) -t -i gor go run $(SOURCE) --input-dummy=0 --output-http="http://localhost:9000" --input-raw :9000 --input-http :9000 --verbose --debug --middleware "./examples/middleware/echo.sh" drun-2: - docker run -v `pwd`:$(SOURCE_PATH) -t -i gor go run $(SOURCE) --input-http :9001 --output-dummy=0 + docker run -v `pwd`:$(SOURCE_PATH) -t -i gor go run $(SOURCE) --input-file ./fixtures/requests.gor --output-dummy=0 drecord: docker run -v `pwd`:$(SOURCE_PATH) -t -i gor go run $(SOURCE) --input-dummy=0 --output-file=requests.gor --verbose --debug diff --git a/input_file.go b/input_file.go index 60ec9580..d0443452 100644 --- a/input_file.go +++ b/input_file.go @@ -61,15 +61,18 @@ func (i *FileInput) emit() { buf := scanner.Bytes() meta := payloadMeta(buf) - if meta[0][0] == RequestPayload && lastTime != 0 { + if meta[0][0] == RequestPayload { ts, _ := strconv.ParseInt(string(meta[2]), 10, 64) - timeDiff := ts - lastTime - if i.speedFactor != 1 { - timeDiff = int64(float64(timeDiff) / i.speedFactor) - } + if lastTime != 0 { + timeDiff := ts - lastTime + + if i.speedFactor != 1 { + timeDiff = int64(float64(timeDiff) / i.speedFactor) + } - time.Sleep(time.Duration(timeDiff)) + time.Sleep(time.Duration(timeDiff)) + } lastTime = ts }