From 0d5b2abe20ad58ca372274144ae1b74bd786f08b Mon Sep 17 00:00:00 2001 From: Vladimir Stepanov Date: Thu, 16 Jun 2022 17:08:47 +0600 Subject: [PATCH] refactoring: rename all methods and errors working with parallel containers --- docs/features/creating_container.md | 6 +++--- parallel.go | 33 ++++++++++++++--------------- parallel_test.go | 6 +++--- 3 files changed, 22 insertions(+), 23 deletions(-) diff --git a/docs/features/creating_container.md b/docs/features/creating_container.md index 533061a13f..762312451e 100644 --- a/docs/features/creating_container.md +++ b/docs/features/creating_container.md @@ -84,7 +84,7 @@ func TestIntegrationNginxLatestReturn(t *testing.T) { # Parallel running -`testcontainers.GenericParallelContainers` - defines the containers that should be run in parallel mode. +`testcontainers.ParallelContainers` - defines the containers that should be run in parallel mode. ```go ctx := context.Background() @@ -112,10 +112,10 @@ requests := []GenericContainerRequest{ }, } -res, err := GenericParallelContainers(ctx, requests, GenericParallelOptions{}) +res, err := ParallelContainers(ctx, requests, ParallelContainersOptions{}) if err != nil { - e, ok := err.(GenericParallelErrors) + e, ok := err.(ParallelContainersError) if !ok { log.Fatalf("unknown error: %v", err) } diff --git a/parallel.go b/parallel.go index 3c84d65039..c319fbf3f5 100644 --- a/parallel.go +++ b/parallel.go @@ -10,36 +10,36 @@ const ( defaultWorkersCount = 8 ) -// GenericParallelOptions represents additional options for running +// ParallelContainersOptions represents additional options for parallel running // * WorkersCount - count of parallel workers. if field empty(zero), default value will be 'defaultWorkersCount' -type GenericParallelOptions struct { +type ParallelContainersOptions struct { WorkersCount int } -// GenericContainerRequestError represents error from parallel request -type GenericContainerRequestError struct { +// ParallelContainersRequestError represents error from parallel request +type ParallelContainersRequestError struct { Request GenericContainerRequest Error error } -type GenericParallelErrors struct { - Errors []GenericContainerRequestError +type ParallelContainersError struct { + Errors []ParallelContainersRequestError } -func (gpe GenericParallelErrors) Error() string { +func (gpe ParallelContainersError) Error() string { return fmt.Sprintf("%v", gpe.Errors) } -func genericContainerRunner( +func parallelContainersRunner( ctx context.Context, requests <-chan GenericContainerRequest, - errors chan<- GenericContainerRequestError, + errors chan<- ParallelContainersRequestError, containers chan<- Container, wg *sync.WaitGroup) { for req := range requests { c, err := GenericContainer(ctx, req) if err != nil { - errors <- GenericContainerRequestError{ + errors <- ParallelContainersRequestError{ Request: req, Error: err, } @@ -50,8 +50,8 @@ func genericContainerRunner( wg.Done() } -// GenericParallelContainers creates a generic containers with parameters and run it in parallel mode -func GenericParallelContainers(ctx context.Context, reqs []GenericContainerRequest, opt GenericParallelOptions) ([]Container, error) { +// ParallelContainers creates a generic containers with parameters and run it in parallel mode +func ParallelContainers(ctx context.Context, reqs []GenericContainerRequest, opt ParallelContainersOptions) ([]Container, error) { if opt.WorkersCount == 0 { opt.WorkersCount = defaultWorkersCount } @@ -62,19 +62,19 @@ func GenericParallelContainers(ctx context.Context, reqs []GenericContainerReque } tasksChan := make(chan GenericContainerRequest, tasksChanSize) - errsChan := make(chan GenericContainerRequestError) + errsChan := make(chan ParallelContainersRequestError) resChan := make(chan Container) waitRes := make(chan struct{}) containers := make([]Container, 0) - errors := make([]GenericContainerRequestError, 0) + errors := make([]ParallelContainersRequestError, 0) wg := sync.WaitGroup{} wg.Add(tasksChanSize) // run workers for i := 0; i < tasksChanSize; i++ { - go genericContainerRunner(ctx, tasksChan, errsChan, resChan, &wg) + go parallelContainersRunner(ctx, tasksChan, errsChan, resChan, &wg) } go func() { @@ -113,9 +113,8 @@ func GenericParallelContainers(ctx context.Context, reqs []GenericContainerReque <-waitRes if len(errors) == 0 { - return containers, GenericParallelErrors{Errors: errors} + return containers, ParallelContainersError{Errors: errors} } return containers, nil - } diff --git a/parallel_test.go b/parallel_test.go index 1893d3dadb..72ce0ffc32 100644 --- a/parallel_test.go +++ b/parallel_test.go @@ -5,7 +5,7 @@ import ( "testing" ) -func TestGenericParallelContainers(t *testing.T) { +func TestParallelContainers(t *testing.T) { tests := []struct { name string reqs []GenericContainerRequest @@ -69,10 +69,10 @@ func TestGenericParallelContainers(t *testing.T) { for _, tc := range tests { t.Run(tc.name, func(t *testing.T) { - res, err := GenericParallelContainers(context.Background(), tc.reqs, GenericParallelOptions{}) + res, err := ParallelContainers(context.Background(), tc.reqs, ParallelContainersOptions{}) if err != nil && tc.expErrors > 0 { - e, _ := err.(GenericParallelErrors) + e, _ := err.(ParallelContainersError) if len(e.Errors) != tc.expErrors { t.Fatalf("expected erorrs: %d, got: %d\n", tc.expErrors, len(e.Errors))