kraken
95 строк · 2.2 Кб
1// Copyright (c) 2016-2019 Uber Technologies, Inc.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14package networkevent15
16import (17"bufio"18"encoding/json"19"io/ioutil"20"os"21"path/filepath"22"testing"23
24"github.com/uber/kraken/core"25
26"github.com/stretchr/testify/require"27)
28
29func TestProducerCreatesAndReusesFile(t *testing.T) {30require := require.New(t)31
32h := core.InfoHashFixture()33peer1 := core.PeerIDFixture()34peer2 := core.PeerIDFixture()35
36dir, err := ioutil.TempDir("", "")37require.NoError(err)38defer os.RemoveAll(dir)39
40config := Config{41Enabled: true,42LogPath: filepath.Join(dir, "netevents"),43}44
45events := []*Event{46ReceivePieceEvent(h, peer1, peer2, 1),47ReceivePieceEvent(h, peer1, peer2, 2),48ReceivePieceEvent(h, peer1, peer2, 3),49ReceivePieceEvent(h, peer1, peer2, 4),50}51
52// First producer should create the file.53p, err := NewProducer(config)54require.NoError(err)55for _, e := range events[:2] {56p.Produce(e)57}58require.NoError(p.Close())59
60// Second producer should reuse the existing file.61p, err = NewProducer(config)62require.NoError(err)63for _, e := range events[2:] {64p.Produce(e)65}66require.NoError(p.Close())67
68f, err := os.Open(config.LogPath)69require.NoError(err)70defer f.Close()71
72var results []*Event73s := bufio.NewScanner(f)74s.Split(bufio.ScanLines)75for s.Scan() {76e := new(Event)77require.NoError(json.Unmarshal(s.Bytes(), e))78results = append(results, e)79}80
81require.Equal(StripTimestamps(events), StripTimestamps(results))82}
83
84func TestDisabledProducerNoops(t *testing.T) {85require := require.New(t)86
87h := core.InfoHashFixture()88peer1 := core.PeerIDFixture()89peer2 := core.PeerIDFixture()90
91p, err := NewProducer(Config{})92require.NoError(err)93
94p.Produce(ReceivePieceEvent(h, peer1, peer2, 1))95}
96