Skip to content

Commit

Permalink
refactor: Expose various test types/functions/variables for other pac…
Browse files Browse the repository at this point in the history
…kages. (#569)

* refactor: Expose various test types/functions/variables for other packages.

To support future API endpoints being located outside of the 'fastly'
package, a number of types/functions/variables used in the
implementations of those endpoints (and their unit tests) need to be
exposed from the 'fastly' package.

In addition, the 'fastly_test.go' file must be given a different name,
as files named '..._test.go' cannot expose any of their declarations
outside of their package.

Finally, add support for Next-Gen WAF workspace IDs along side
Delivery and Compute service IDs, as future API endpoints will require
them.

* Update fastly/fastly_test_utils.go

Co-authored-by: Mark McDonnell <[email protected]>

---------

Co-authored-by: Mark McDonnell <[email protected]>
  • Loading branch information
kpfleming and Integralist authored Dec 10, 2024
1 parent 58e4f6e commit 130b93c
Show file tree
Hide file tree
Showing 180 changed files with 2,516 additions and 2,489 deletions.
9 changes: 8 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,13 @@ GOMAXPROCS ?= 4

NAME := $(notdir $(shell pwd))

# Test Service IDs
# Test Resource IDs
FASTLY_TEST_DELIVERY_SERVICE_ID ?=
DEFAULT_FASTLY_TEST_DELIVERY_SERVICE_ID = kKJb5bOFI47uHeBVluGfX1
FASTLY_TEST_COMPUTE_SERVICE_ID ?=
DEFAULT_FASTLY_TEST_COMPUTE_SERVICE_ID = XsjdElScZGjmfCcTwsYRC1
FASTLY_TEST_NGWAF_WORKSPACE_ID ?=
DEFAULT_FASTLY_TEST_NGWAF_WORKSPACE_ID = alk6DTsYKHKucJCOIavaJM
FASTLY_API_KEY ?=
#
# Enables support for tools such as https://github.com/rakyll/gotest
Expand Down Expand Up @@ -73,6 +75,11 @@ fix-compute-fixtures: ## Updates test fixtures with a specified default Compute
@$(shell pwd)/scripts/fixFixtures.sh ${FASTLY_TEST_COMPUTE_SERVICE_ID} ${DEFAULT_FASTLY_TEST_COMPUTE_SERVICE_ID}
.PHONY: fix-compute-fixtures

fix-ngwaf-fixtures: ## Updates test fixtures with a specified default Next-Gen WAF workspace ID.
@echo "==> Updating fixtures"
@$(shell pwd)/scripts/fixFixtures.sh ${FASTLY_TEST_NGWAF_WORKSPACE_ID} ${DEFAULT_FASTLY_TEST_NGWAF_WORKSPACE_ID}
.PHONY: fix-ngwaf-fixtures

check-imports: ## A check which lists improperly-formatted imports, if they exist.
@$(shell pwd)/scripts/check-imports.sh
.PHONY: check-imports
Expand Down
21 changes: 14 additions & 7 deletions TESTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,13 @@
Go Fastly uses [go-vcr](https://github.com/dnaeon/go-vcr) to "record"
and "replay" API request fixtures to improve the speed and portability
of integration tests. The test suite uses a pair of service IDs (one
for Delivery, one for Compute) for its test cases.
for Delivery, one for Compute) for its test cases. It also uses one
Next-Gen WAF workspace ID for various test cases.

Contributors without access to the test services can still update the
fixtures but with some additional steps required. Below is an example
workflow for updating a set of fixture files (where `...` should be
replaced with an appropriate value):
Contributors without access to the test services or workspace can
still update the fixtures but with some additional steps
required. Below is an example workflow for updating a set of fixture
files (where `...` should be replaced with an appropriate value):

```sh
# Remove all YAML fixture files from the specified directory.
Expand All @@ -20,18 +21,20 @@ rm -r fastly/fixtures/.../*
#
# FASTLY_TEST_DELIVERY_SERVICE_ID: should correspond to a real Delivery service you control.
# FASTLY_TEST_COMPUTE_SERVICE_ID: should correspond to a real Compute service you control.
# FASTLY_TEST_NGWAF_WORKSPACE_ID: should correspond to a real Next-Gen WAF workspace you control.
# FASTLY_API_KEY: should be a real token associated with the services you control.
# TESTARGS: allows you to use the -run flag of the 'go test' command.
#
make test FASTLY_TEST_DELIVERY_SERVICE_ID="..." FASTLY_TEST_COMPUTE_SERVICE_ID="..." FASTLY_API_KEY="..." TESTARGS="-run=..."
make test FASTLY_TEST_DELIVERY_SERVICE_ID="..." FASTLY_TEST_COMPUTE_SERVICE_ID="..." FASTLY_TEST_NGWAF_WORKSPACE_ID="..." FASTLY_API_KEY="..." TESTARGS="-run=..."
```

> **NOTE**: to run the tests with go-vcr disabled, set `VCR_DISABLE=1` (`make test-full` does this).
When adding or updating client code and integration tests,
contributors should record a new set of fixtures. Before submitting a
pull request with new or updated fixtures, we ask that contributors
update them to use the default service IDs by running two commands:
update them to use the default service IDs and workspace ID by running
three commands:

```sh
make fix-delivery-fixtures FASTLY_TEST_DELIVERY_SERVICE_ID=<your Delivery SID>
Expand All @@ -41,6 +44,10 @@ make fix-delivery-fixtures FASTLY_TEST_DELIVERY_SERVICE_ID=<your Delivery SID>
make fix-compute-fixtures FASTLY_TEST_COMPUTE_SERVICE_ID=<your Compute SID>
```

```sh
make fix-ngwaf-fixtures FASTLY_TEST_NGWAF_WORKSPACE_ID=<your Next-Gen WAF workspace ID>
```

### Important Test Tips!

There are two important things external contributors need to do when running the tests:
Expand Down
6 changes: 3 additions & 3 deletions fastly/account_event_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ func TestClient_APIEvents(t *testing.T) {

var err error
var events GetAPIEventsResponse
record(t, "events/get_events", func(c *Client) {
Record(t, "events/get_events", func(c *Client) {
events, err = c.GetAPIEvents(&GetAPIEventsFilterInput{
PageNumber: 1,
MaxResults: 1,
Expand All @@ -25,7 +25,7 @@ func TestClient_APIEvents(t *testing.T) {
}

var event *Event
record(t, "events/get_event", func(c *Client) {
Record(t, "events/get_event", func(c *Client) {
event, err = c.GetAPIEvent(&GetAPIEventInput{
EventID: events.Events[0].ID,
})
Expand All @@ -40,7 +40,7 @@ func TestClient_APIEvents(t *testing.T) {

func TestClient_GetAPIEvent_validation(t *testing.T) {
var err error
_, err = testClient.GetAPIEvent(&GetAPIEventInput{
_, err = TestClient.GetAPIEvent(&GetAPIEventInput{
EventID: "",
})
if err != ErrMissingEventID {
Expand Down
10 changes: 5 additions & 5 deletions fastly/acl.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ func (c *Client) ListACLs(i *ListACLsInput) ([]*ACL, error) {
defer resp.Body.Close()

var as []*ACL
if err := decodeBodyMap(resp.Body, &as); err != nil {
if err := DecodeBodyMap(resp.Body, &as); err != nil {
return nil, err
}
return as, nil
Expand Down Expand Up @@ -77,7 +77,7 @@ func (c *Client) CreateACL(i *CreateACLInput) (*ACL, error) {
defer resp.Body.Close()

var a *ACL
if err := decodeBodyMap(resp.Body, &a); err != nil {
if err := DecodeBodyMap(resp.Body, &a); err != nil {
return nil, err
}
return a, nil
Expand Down Expand Up @@ -114,7 +114,7 @@ func (c *Client) DeleteACL(i *DeleteACLInput) error {
defer resp.Body.Close()

var r *statusResp
if err := decodeBodyMap(resp.Body, &r); err != nil {
if err := DecodeBodyMap(resp.Body, &r); err != nil {
return err
}
if !r.Ok() {
Expand Down Expand Up @@ -154,7 +154,7 @@ func (c *Client) GetACL(i *GetACLInput) (*ACL, error) {
defer resp.Body.Close()

var a *ACL
if err := decodeBodyMap(resp.Body, &a); err != nil {
if err := DecodeBodyMap(resp.Body, &a); err != nil {
return nil, err
}
return a, nil
Expand Down Expand Up @@ -193,7 +193,7 @@ func (c *Client) UpdateACL(i *UpdateACLInput) (*ACL, error) {
defer resp.Body.Close()

var a *ACL
if err := decodeBodyMap(resp.Body, &a); err != nil {
if err := DecodeBodyMap(resp.Body, &a); err != nil {
return nil, err
}

Expand Down
26 changes: 13 additions & 13 deletions fastly/acl_entries_batch_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ func TestClient_BatchModifyACLEntries_Create(t *testing.T) {
testService := createTestService(t, fixtureBase+"create_service", nameSuffix)
defer deleteTestService(t, fixtureBase+"delete_service", *testService.ServiceID)

testVersion := createTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)
testVersion := CreateTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)

testACL := createTestACL(t, fixtureBase+"create_acl", *testService.ServiceID, *testVersion.Number, nameSuffix)
defer deleteTestACL(t, testACL, fixtureBase+"delete_acl")
Expand Down Expand Up @@ -41,7 +41,7 @@ func TestClient_BatchModifyACLEntries_Create(t *testing.T) {

// When: I execute the batch create operations against the Fastly API,
var err error
record(t, fixtureBase+"create_acl_entries", func(c *Client) {
Record(t, fixtureBase+"create_acl_entries", func(c *Client) {
err = c.BatchModifyACLEntries(batchCreateOperations)
})
if err != nil {
Expand All @@ -50,7 +50,7 @@ func TestClient_BatchModifyACLEntries_Create(t *testing.T) {

// Then: I expect to be able to list all of the created ACL entries.
var actualACLEntries []*ACLEntry
record(t, fixtureBase+"list_after_create", func(c *Client) {
Record(t, fixtureBase+"list_after_create", func(c *Client) {
actualACLEntries, err = c.ListACLEntries(&ListACLEntriesInput{
ServiceID: *testService.ServiceID,
ACLID: *testACL.ACLID,
Expand Down Expand Up @@ -109,7 +109,7 @@ func TestClient_BatchModifyACLEntries_Delete(t *testing.T) {
testService := createTestService(t, fixtureBase+"create_service", nameSuffix)
defer deleteTestService(t, fixtureBase+"delete_service", *testService.ServiceID)

testVersion := createTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)
testVersion := CreateTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)

testACL := createTestACL(t, fixtureBase+"create_acl", *testService.ServiceID, *testVersion.Number, nameSuffix)
defer deleteTestACL(t, testACL, fixtureBase+"delete_acl")
Expand All @@ -136,15 +136,15 @@ func TestClient_BatchModifyACLEntries_Delete(t *testing.T) {
}

var err error
record(t, fixtureBase+"create_acl_entries", func(c *Client) {
Record(t, fixtureBase+"create_acl_entries", func(c *Client) {
err = c.BatchModifyACLEntries(batchCreateOperations)
})
if err != nil {
t.Fatal(err)
}

var createdACLEntries []*ACLEntry
record(t, fixtureBase+"list_before_delete", func(client *Client) {
Record(t, fixtureBase+"list_before_delete", func(client *Client) {
createdACLEntries, err = client.ListACLEntries(&ListACLEntriesInput{
ServiceID: *testService.ServiceID,
ACLID: *testACL.ACLID,
Expand All @@ -170,7 +170,7 @@ func TestClient_BatchModifyACLEntries_Delete(t *testing.T) {
},
}

record(t, fixtureBase+"delete_acl_entries", func(c *Client) {
Record(t, fixtureBase+"delete_acl_entries", func(c *Client) {
err = c.BatchModifyACLEntries(batchDeleteOperations)
})
if err != nil {
Expand All @@ -179,7 +179,7 @@ func TestClient_BatchModifyACLEntries_Delete(t *testing.T) {

// Then: I expect to be able to list a single ACL entry.
var actualACLEntries []*ACLEntry
record(t, fixtureBase+"list_after_delete", func(client *Client) {
Record(t, fixtureBase+"list_after_delete", func(client *Client) {
actualACLEntries, err = client.ListACLEntries(&ListACLEntriesInput{
ServiceID: *testService.ServiceID,
ACLID: *testACL.ACLID,
Expand Down Expand Up @@ -208,7 +208,7 @@ func TestClient_BatchModifyACLEntries_Update(t *testing.T) {
testService := createTestService(t, fixtureBase+"create_service", nameSuffix)
defer deleteTestService(t, fixtureBase+"delete_service", *testService.ServiceID)

testVersion := createTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)
testVersion := CreateTestVersion(t, fixtureBase+"create_version", *testService.ServiceID)

testACL := createTestACL(t, fixtureBase+"create_acl", *testService.ServiceID, *testVersion.Number, nameSuffix)
defer deleteTestACL(t, testACL, fixtureBase+"delete_acl")
Expand All @@ -235,15 +235,15 @@ func TestClient_BatchModifyACLEntries_Update(t *testing.T) {
}

var err error
record(t, fixtureBase+"create_acl_entries", func(c *Client) {
Record(t, fixtureBase+"create_acl_entries", func(c *Client) {
err = c.BatchModifyACLEntries(batchCreateOperations)
})
if err != nil {
t.Fatal(err)
}

var createdACLEntries []*ACLEntry
record(t, fixtureBase+"list_before_update", func(client *Client) {
Record(t, fixtureBase+"list_before_update", func(client *Client) {
createdACLEntries, err = client.ListACLEntries(&ListACLEntriesInput{
ServiceID: *testService.ServiceID,
ACLID: *testACL.ACLID,
Expand Down Expand Up @@ -273,7 +273,7 @@ func TestClient_BatchModifyACLEntries_Update(t *testing.T) {
},
}

record(t, fixtureBase+"update_acl_entries", func(c *Client) {
Record(t, fixtureBase+"update_acl_entries", func(c *Client) {
err = c.BatchModifyACLEntries(batchUpdateOperations)
})
if err != nil {
Expand All @@ -282,7 +282,7 @@ func TestClient_BatchModifyACLEntries_Update(t *testing.T) {

// Then: I expect to be able to list all of the ACL entries with modifications applied to a single item.
var actualACLEntries []*ACLEntry
record(t, fixtureBase+"list_after_update", func(client *Client) {
Record(t, fixtureBase+"list_after_update", func(client *Client) {
actualACLEntries, err = client.ListACLEntries(&ListACLEntriesInput{
ServiceID: *testService.ServiceID,
ACLID: *testACL.ACLID,
Expand Down
10 changes: 5 additions & 5 deletions fastly/acl_entry.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ func (c *Client) GetACLEntry(i *GetACLEntryInput) (*ACLEntry, error) {
defer resp.Body.Close()

var e *ACLEntry
if err := decodeBodyMap(resp.Body, &e); err != nil {
if err := DecodeBodyMap(resp.Body, &e); err != nil {
return nil, err
}

Expand Down Expand Up @@ -163,7 +163,7 @@ func (c *Client) CreateACLEntry(i *CreateACLEntryInput) (*ACLEntry, error) {
defer resp.Body.Close()

var e *ACLEntry
if err := decodeBodyMap(resp.Body, &e); err != nil {
if err := DecodeBodyMap(resp.Body, &e); err != nil {
return nil, err
}

Expand Down Expand Up @@ -201,7 +201,7 @@ func (c *Client) DeleteACLEntry(i *DeleteACLEntryInput) error {
defer resp.Body.Close()

var r *statusResp
if err := decodeBodyMap(resp.Body, &r); err != nil {
if err := DecodeBodyMap(resp.Body, &r); err != nil {
return err
}

Expand Down Expand Up @@ -251,7 +251,7 @@ func (c *Client) UpdateACLEntry(i *UpdateACLEntryInput) (*ACLEntry, error) {
defer resp.Body.Close()

var e *ACLEntry
if err := decodeBodyMap(resp.Body, &e); err != nil {
if err := DecodeBodyMap(resp.Body, &e); err != nil {
return nil, err
}

Expand Down Expand Up @@ -307,5 +307,5 @@ func (c *Client) BatchModifyACLEntries(i *BatchModifyACLEntriesInput) error {

var batchModifyResult map[string]string

return decodeBodyMap(resp.Body, &batchModifyResult)
return DecodeBodyMap(resp.Body, &batchModifyResult)
}
Loading

0 comments on commit 130b93c

Please sign in to comment.