etoe

package
v0.0.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 25, 2022 License: MIT Imports: 6 Imported by: 0

README

Setup for End to End Integration Test

Introduction

The Kusto SDK is setup to use hermetic tests throughout the SDK. This makes testing faster and is preferable to large integration tests that often miss all the corner cases.

For anyone who wants to make some change and runs: go test ./..., everything should just work, except this integration test.
It will be skipped until you setup the necessary config file.

In addition, if using the -short option, the integration test will be skipped.

go test -short ./...

Before any changes will be accepted into the SDK, you will need to setup and pass the integration test. While integration tests are error prone, they do offer the only method to check the SDK against the real backend.

Setup

The only thing needed to test Kusto is a:

  • Kusto instance
  • Credentials
  • Principal names

Setting up a Kusto instance is beyond this short guide. See the quickstart guide.

Once the kusto instance is setup, you will need to create a config.json file in the directory where this README is located.

It will need to have the following content:

{
    "Endpoint": "https://[cluster name].westus.kusto.windows.net",
	"Database": "[database_name]",
	"ClientID": "[client ID]",
	"ClientSecret": "[client secret]",
    "TenantID": "[tenant ID]",
    "Principals": ["[principal name]", "[prinicipal name]"]
}
  • Anything within [] must be replaced. The [] should be removed.

Most of these are self explanatory, with the exception of Principals.

Principals are found by running the following management query:

.show database e2e principals

You will need to extract a few PrincipalDisplayName's and insert them here. Something like:

"Principals": ["John Doak (upn: jdoak@microsoft.com)", "Daniel Dubovski (upn: dadubovs@microsoft.com)"]

Running the test

Simply run this from the directory:

go test -timeout=10m

Or you can do this from the root:

go test -timeout=10m ./...

Normally this runs under 2 minutes. The streaming test is our slow one.

Caveats

There is no compatibility guarentee on tests or the config.json file. During any update, including minor or patch semver changes, we may change the config.json format.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config struct {
	// Endpoint is the endpoint name to connect with
	Endpoint string
	// SecondaryEndpoint is the endpoint name to connect with for the secondary cluster
	SecondaryEndpoint string
	// Database is the name of an existing database that can be used for tests
	Database string
	// SecondaryDatabase is the name of an existing database in the secondary that can be used for tests
	SecondaryDatabase string
	// ClientID is the object-id of the principal authorized to connect to the database
	ClientID string
	// ClientSecret is the key used to get a token on behalf of the principal
	ClientSecret string
	// TenantID is the tenant on which the principal exists
	TenantID string
	// contains filtered or unexported fields
}

Config represents a config.json file that must be in the directory and hold information to do the integration tests.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL