2016-02-24 12:14:23 +00:00
|
|
|
package physical
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
"time"
|
2016-04-26 03:10:32 +00:00
|
|
|
|
2016-08-19 20:45:17 +00:00
|
|
|
"github.com/hashicorp/vault/helper/logformat"
|
|
|
|
log "github.com/mgutz/logxi/v1"
|
|
|
|
|
2017-04-17 17:18:34 +00:00
|
|
|
"github.com/Azure/azure-storage-go"
|
2016-02-24 12:14:23 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestAzureBackend(t *testing.T) {
|
|
|
|
if os.Getenv("AZURE_ACCOUNT_NAME") == "" ||
|
|
|
|
os.Getenv("AZURE_ACCOUNT_KEY") == "" {
|
|
|
|
t.SkipNow()
|
|
|
|
}
|
|
|
|
|
|
|
|
accountName := os.Getenv("AZURE_ACCOUNT_NAME")
|
|
|
|
accountKey := os.Getenv("AZURE_ACCOUNT_KEY")
|
|
|
|
|
|
|
|
ts := time.Now().UnixNano()
|
|
|
|
container := fmt.Sprintf("vault-test-%d", ts)
|
|
|
|
|
|
|
|
cleanupClient, _ := storage.NewBasicClient(accountName, accountKey)
|
|
|
|
|
2016-08-19 20:45:17 +00:00
|
|
|
logger := logformat.NewVaultLogger(log.LevelTrace)
|
|
|
|
|
2016-04-26 03:10:32 +00:00
|
|
|
backend, err := NewBackend("azure", logger, map[string]string{
|
2016-02-24 12:14:23 +00:00
|
|
|
"container": container,
|
|
|
|
"accountName": accountName,
|
|
|
|
"accountKey": accountKey,
|
|
|
|
})
|
|
|
|
|
|
|
|
defer func() {
|
2017-04-17 18:52:52 +00:00
|
|
|
contObj := cleanupClient.GetBlobService().GetContainerReference(container)
|
|
|
|
contObj.DeleteIfExists()
|
2016-02-24 12:14:23 +00:00
|
|
|
}()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
testBackend(t, backend)
|
|
|
|
testBackend_ListPrefix(t, backend)
|
|
|
|
}
|