refactor: move bytecounter to internal (#391)
It's generic enough to live outside of engine/netx. Occurred to me while working on https://github.com/ooni/probe/issues/1687.
This commit is contained in:
		
							parent
							
								
									520398dd8e
								
							
						
					
					
						commit
						23bc261464
					
				| @ -1,11 +1,18 @@ | ||||
| // Package bytecounter contains code to track the number of | ||||
| // bytes sent and received by a probe. | ||||
| package bytecounter | ||||
| 
 | ||||
| import "github.com/ooni/probe-cli/v3/internal/atomicx" | ||||
| 
 | ||||
| // Counter counts bytes sent and received. | ||||
| type Counter struct { | ||||
| 	// Received contains the bytes received. You MUST initialize | ||||
| 	// this field, or you can just use the New factory. | ||||
| 	Received *atomicx.Int64 | ||||
| 	Sent     *atomicx.Int64 | ||||
| 
 | ||||
| 	// Sent contains the bytes sent. You MUST initialize | ||||
| 	// this field, or you can just use the New factory. | ||||
| 	Sent *atomicx.Int64 | ||||
| } | ||||
| 
 | ||||
| // New creates a new Counter. | ||||
| @ -1,13 +1,9 @@ | ||||
| package bytecounter_test | ||||
| package bytecounter | ||||
| 
 | ||||
| import ( | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| ) | ||||
| import "testing" | ||||
| 
 | ||||
| func TestGood(t *testing.T) { | ||||
| 	counter := bytecounter.New() | ||||
| 	counter := New() | ||||
| 	counter.CountBytesReceived(16384) | ||||
| 	counter.CountKibiBytesReceived(10) | ||||
| 	counter.CountBytesSent(2048) | ||||
| @ -9,9 +9,9 @@ import ( | ||||
| 	"os" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/geolocate" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/model" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/dialer" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/httptransport" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/probeservices" | ||||
|  | ||||
| @ -6,8 +6,8 @@ import ( | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/apex/log" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| ) | ||||
| 
 | ||||
| // resolvemaker contains rules for making a resolver. | ||||
|  | ||||
| @ -6,7 +6,7 @@ import ( | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/apex/log" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| ) | ||||
| 
 | ||||
| func TestDefaultByteCounter(t *testing.T) { | ||||
|  | ||||
| @ -33,7 +33,7 @@ import ( | ||||
| 	"sync" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/multierror" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/runtimex" | ||||
| ) | ||||
|  | ||||
| @ -4,7 +4,7 @@ import ( | ||||
| 	"context" | ||||
| 	"net" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| ) | ||||
| 
 | ||||
| // byteCounterDialer is a byte-counting-aware dialer. To perform byte counting, you | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"net/http" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/mockablex" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/iox" | ||||
| ) | ||||
|  | ||||
| @ -4,7 +4,7 @@ import ( | ||||
| 	"io" | ||||
| 	"net/http" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| ) | ||||
| 
 | ||||
| // ByteCountingTransport is a RoundTripper that counts bytes. | ||||
|  | ||||
| @ -8,7 +8,7 @@ import ( | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/httptransport" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/iox" | ||||
| ) | ||||
|  | ||||
| @ -7,8 +7,8 @@ import ( | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/apex/log" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/errorx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/trace" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/iox" | ||||
|  | ||||
| @ -31,7 +31,7 @@ import ( | ||||
| 	"net/url" | ||||
| 
 | ||||
| 	"github.com/lucas-clemente/quic-go" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/dialer" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/httptransport" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/quicdialer" | ||||
|  | ||||
| @ -8,8 +8,8 @@ import ( | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/apex/log" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/httptransport" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/resolver" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/tlsdialer" | ||||
|  | ||||
| @ -11,11 +11,11 @@ import ( | ||||
| 	"sync" | ||||
| 
 | ||||
| 	"github.com/ooni/probe-cli/v3/internal/atomicx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/geolocate" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/internal/sessionresolver" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/model" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/netx/bytecounter" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/engine/probeservices" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/kvstore" | ||||
| 	"github.com/ooni/probe-cli/v3/internal/platform" | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user