Giovanni
An alternative Azure Storage SDK for Go
This repository is an alternative Azure Storage SDK for Go; which supports for:
At this time we support the following API Versions:
2020-08-04
(./storage/2020-08-04
)
We're also open to supporting other versions of the Azure Storage APIs as necessary.
Documentation for how to use each SDK can be found within the README for that SDK version - for example here's the README for 2020-08-04.
Each Package also contains Unit and Acceptance tests to ensure that the functionality works; instructions on how to run the tests can be found below.
Mission Statement
Fundamentally: developers should be able to pick which version of the Azure API they target using this SDK.
As such, there's two main goals here:
To ensure that each of these scenarios is possible - we have Acceptance and Unit Tests to confirm that the functionality in these versions works - and will use SemVer as appropriate.
Future Enhancements
At this time this SDK is mostly feature complete, with a couple of notable additions (since we didn't need them).
Whilst it's possible to create Snapshots (for example, of a Container) - at this time most SDK calls don't support specifying the optional query-string value for snapshot
.
In addition, we also don't support the timeout
querystring on every API call; this is because instead all SDK methods take a context
object, which allows a timeout to be set (albeit on the Client rather than the Remote API Call).
In both instances this is because we didn't need this functionality for our use-cases - but feel free to send a PR if you need this.
Licence
Apache 2.0
Technical Implementation
This SDK now uses github.com/hashicorp/go-azure-sdk/sdk as the authentication and transport layer.
Depending on the API Version / API being used - different authentication mechanisms are possible (see the README within the specific SDK for more info (example). In all cases one of the following Authorizers will be required:
- An Authorizer for Azure Active Directory
- A SharedKey Authorizer (supports both SharedKey and SharedKeyLite)
Examples for all of these can be found below in the Examples Directory.
Running the Tests
Each package contains both Unit and Acceptance Tests which provision a real Storage Account on Azure, and then run tests against that.
To run those, the following Environment Variables need to be set:
ARM_TENANT_ID
- The ID of the Tenant where tests should be run, such as 00000000-0000-0000-0000-000000000000
.
ARM_SUBSCRIPTION_ID
- The ID of the Subscription where tests should be run, such as 00000000-0000-0000-0000-000000000000
.
ARM_CLIENT_ID
- The ID of the AzureAD Application (also known as a Client ID), such as 00000000-0000-0000-0000-000000000000
.
ARM_CLIENT_SECRET
- The Client Secret/Password for a Service Principal where tests should be run.
ARM_ENVIRONMENT
- The name of the Azure Environment where the tests should be run, such as Public
or Germany
.
ARM_TEST_LOCATION
- The name of the Azure Region where resources provisioned by the tests should be created, such as West Europe
.
ACCTEST
- confirms that you want the tests to be run, set this to any value.
Once those Environment Variables are set - you should be able to run:
$ ACCTEST=1 go test -v ./storage/...
You can also run them for a specific API version by running:
$ ACCTEST=1 go test -v ./storage/2020-08-04/...
Debugging
You can see the Requests/Responses from this SDK by setting the Environment Variable TEST_LOG
to any value.