Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add localstack module #800

Merged
merged 60 commits into from
Feb 14, 2023
Merged
Changes from 1 commit
Commits
Show all changes
60 commits
Select commit Hold shift + click to select a range
3fab103
chore: add localstack basic example
mdelapenya Jan 30, 2023
6074b03
chore: add wait for log
mdelapenya Jan 30, 2023
21493cb
chore: add Docker socket binding
mdelapenya Jan 30, 2023
5461f69
chore: support defining legacy mode
mdelapenya Jan 30, 2023
a477156
chore: support passing services and configuring them
mdelapenya Feb 1, 2023
c8b67e5
chore: simplify the creation of a localstack container request
mdelapenya Feb 1, 2023
a0eaf50
chore: support configuring the AWS region
mdelapenya Feb 1, 2023
59b8cd7
chore: expose localstack container
mdelapenya Feb 1, 2023
5013670
chore: support for retrieving the endpoint of a given service
mdelapenya Feb 1, 2023
595f73c
chore: store enabled services in the localstack container
mdelapenya Feb 1, 2023
6eab52d
chore: store the region in the localstack container
mdelapenya Feb 1, 2023
3b59457
chore: apply default region when needed
mdelapenya Feb 1, 2023
de6fea7
chore: support passing version and legacyMode as functional options
mdelapenya Feb 1, 2023
4c863d9
chore: support for overriding the container request with a functional…
mdelapenya Feb 2, 2023
902869b
chore: remove useless method for retrieving the internal endpoint of …
mdelapenya Feb 2, 2023
f3c1754
chore: simplify unit tests
mdelapenya Feb 2, 2023
5ed9cc5
chore: create aws session using v1
mdelapenya Feb 2, 2023
bffe24a
chore: add S3 tests
mdelapenya Feb 2, 2023
c94594f
chore: rename start localstack function
mdelapenya Feb 2, 2023
6c83776
chore: define default functions as vars
mdelapenya Feb 2, 2023
fa939b9
chore: add tests for legacy mode
mdelapenya Feb 2, 2023
6e131ba
chore: move the Session code to the tests
mdelapenya Feb 2, 2023
900b825
docs: use S3 in the docs
mdelapenya Feb 2, 2023
1adcfa2
Merge branch 'main' into localstack-module
mdelapenya Feb 7, 2023
5bd4138
fix: read the expected daemon host from the provider
mdelapenya Feb 7, 2023
ddb3f83
chore: move v1 tests to its own test package
mdelapenya Feb 7, 2023
0f90131
feat: add example test for S3 using v2
mdelapenya Feb 7, 2023
178b9e9
chore: store localstack credentials in a struct
mdelapenya Feb 7, 2023
23d553c
feat: create a functional opt for passing the AWS credentials
mdelapenya Feb 7, 2023
2db880d
chore: define defaults for the AWS credentials
mdelapenya Feb 7, 2023
c9c551b
chore: include a test for overriding the image
mdelapenya Feb 8, 2023
87ec202
chore: remove withCredentials
mdelapenya Feb 8, 2023
11a6da9
chore: remove withRegion
mdelapenya Feb 8, 2023
767a073
chore: remove withVersion
mdelapenya Feb 8, 2023
4d70f27
chore: rename configure method
mdelapenya Feb 8, 2023
6d51794
chore: reorder container configuration
mdelapenya Feb 8, 2023
a79b3d2
chore: move to types
mdelapenya Feb 8, 2023
2639aa5
chor: export structs
mdelapenya Feb 8, 2023
8cbf21b
docs: document exported functions
mdelapenya Feb 8, 2023
7be6c70
docs: document how to create localstack container
mdelapenya Feb 8, 2023
91139cf
docs: reorder
mdelapenya Feb 8, 2023
55ce21c
docs: document containerRequest override
mdelapenya Feb 8, 2023
97abda8
docs: document the container functional opts
mdelapenya Feb 8, 2023
dfee950
chore: be more explicit in comment
mdelapenya Feb 9, 2023
8f1a256
chore: convert into real module
mdelapenya Feb 10, 2023
9f01c71
chore: remove support for legacy mode
mdelapenya Feb 10, 2023
4a435a3
chore: move tests
mdelapenya Feb 10, 2023
40e4f65
fix: update module paths
mdelapenya Feb 10, 2023
5ce1ce6
fix: update tests after moving an example to modules
mdelapenya Feb 10, 2023
bb4e2a8
chore: bump default version to 1.3.1
mdelapenya Feb 13, 2023
f2026e9
chore: remove Port from the Service struct
mdelapenya Feb 13, 2023
f3da875
fix: wrong relative path to the docs
mdelapenya Feb 14, 2023
cca2a3b
chore: remove any code to Services
mdelapenya Feb 14, 2023
87b2021
chore: adjust unit tests
mdelapenya Feb 14, 2023
c7a7896
docs: include tests
mdelapenya Feb 14, 2023
a6b26dd
chore: use waitFor HTTP health
mdelapenya Feb 14, 2023
6ccfb56
Merge branch 'main' into localstack-module
mdelapenya Feb 14, 2023
8bba30b
chore: bump to latest version
mdelapenya Feb 14, 2023
4894746
chore: go mod examples
mdelapenya Feb 14, 2023
b325ffc
chore: rename GH action workflow file
mdelapenya Feb 14, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: store localstack credentials in a struct
mdelapenya committed Feb 7, 2023
commit 178b9e944bcd103272a5d37af7d9560007f99932
25 changes: 20 additions & 5 deletions examples/localstack/localstack.go
Original file line number Diff line number Diff line change
@@ -18,17 +18,24 @@ const defaultRegion = "us-east-1"
const defaultVersion = "0.11.2"
const hostnameExternalEnvVar = "HOSTNAME_EXTERNAL"

const AccessKeyID = "accesskey"
const SecretAccessKey = "secretkey"
const Token = "token"
const defaultAccessKeyID = "accesskey"
const defaultSecretAccessKey = "secretkey"
const defaultToken = "token"

// LocalStackContainer represents the LocalStack container type used in the module
type LocalStackContainer struct {
testcontainers.Container
Credentials Credentials
Region string
EnabledServices map[string]Service
}

type Credentials struct {
AccessKeyID string
SecretAccessKey string
Token string
}

// ServicePort returns the port of the given service
func (l *LocalStackContainer) ServicePort(ctx context.Context, service EnabledService) (nat.Port, error) {
if _, ok := l.EnabledServices[service.Name()]; !ok {
@@ -65,13 +72,20 @@ func runInLegacyMode(version string) bool {

// StartContainer creates an instance of the LocalStack container type
func StartContainer(ctx context.Context, overrideReq overrideContainerRequestOption, opts ...localStackContainerOption) (*LocalStackContainer, error) {
credentials := Credentials{
AccessKeyID: defaultAccessKeyID,
SecretAccessKey: defaultSecretAccessKey,
Token: defaultToken,
}

req := testcontainers.ContainerRequest{
Image: "localstack/localstack",
mdelapenya marked this conversation as resolved.
Show resolved Hide resolved
Binds: []string{fmt.Sprintf("%s:/var/run/docker.sock", testcontainersdocker.ExtractDockerHost(ctx))},
WaitingFor: wait.ForLog("Ready.\n").WithOccurrence(1).WithStartupTimeout(2 * time.Minute),
Env: map[string]string{
"AWS_ACCESS_KEY_ID": AccessKeyID,
"AWS_SECRET_ACCESS_KEY": SecretAccessKey,
"AWS_ACCESS_KEY_ID": credentials.AccessKeyID,
"AWS_SECRET_ACCESS_KEY": credentials.SecretAccessKey,
"AWS_SESSION_TOKEN": credentials.Token,
},
}

@@ -131,6 +145,7 @@ func StartContainer(ctx context.Context, overrideReq overrideContainerRequestOpt

c := &LocalStackContainer{
Container: container,
Credentials: credentials,
EnabledServices: enabledServices,
Region: localStackReq.region,
}
2 changes: 1 addition & 1 deletion examples/localstack/v1/s3_test.go
Original file line number Diff line number Diff line change
@@ -37,7 +37,7 @@ func awsSession(ctx context.Context, l *localstack.LocalStackContainer, srv loca
awsConfig := &aws.Config{
Region: aws.String(l.Region),
CredentialsChainVerboseErrors: aws.Bool(true),
Credentials: credentials.NewStaticCredentials(localstack.AccessKeyID, localstack.SecretAccessKey, localstack.Token),
Credentials: credentials.NewStaticCredentials(l.Credentials.AccessKeyID, l.Credentials.SecretAccessKey, l.Credentials.Token),
S3ForcePathStyle: aws.Bool(true),
Endpoint: aws.String(fmt.Sprintf("http://%s:%d", host, mappedPort.Int())),
}
2 changes: 1 addition & 1 deletion examples/localstack/v2/s3_test.go
Original file line number Diff line number Diff line change
@@ -44,7 +44,7 @@ func s3Client(ctx context.Context, l *localstack.LocalStackContainer, srv locals
awsCfg, err := config.LoadDefaultConfig(context.TODO(),
config.WithRegion(l.Region),
config.WithEndpointResolverWithOptions(customResolver),
config.WithCredentialsProvider(credentials.NewStaticCredentialsProvider(localstack.AccessKeyID, localstack.SecretAccessKey, localstack.Token)),
config.WithCredentialsProvider(credentials.NewStaticCredentialsProvider(l.Credentials.AccessKeyID, l.Credentials.SecretAccessKey, l.Credentials.Token)),
)
if err != nil {
return nil, err