Home > Backend Development > Golang > How to manage tests that require API keys

How to manage tests that require API keys

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2024-02-09 23:06:09
forward
944 people have browsed it

如何管理需要 API 密钥的测试

php editor Apple introduces you how to manage tests that require API keys. During development, many applications require API keys to access third-party services. However, managing these keys can become complex and lengthy. To simplify this process, we can adopt some effective management strategies, such as using environment variables, key management tools, key rotation, etc. These methods not only improve security but also make testing and deployment easier for developers. In this article, we'll detail these strategies and provide some suggestions to help you better manage tests that require API keys.

Question content

I have some seal tests that work just fine. Code in foo.go is tested in foo_test.go.

But I also have some tests that require an API key and I want to keep those separate from the sealed tests since we don't run them in CI.

How to effectively isolate these tests in a way that plays well with the Go tooling and ecosystem?

Solution

There are multiple ways to skip testing. Most of them utilize testing.t.skip(now). Here are some common use cases for skipnow. However, since this is just like any old function call, you can get as creative as you want.

Use environment variables

package main

import (
    "os"
    "testing"
)

func testalways(t *testing.t) {
}

func testsometimes(t *testing.t) {
    key := os.getenv("foo_api_key")
    if key == "" {
        t.skip("foo_api_key is empty")
    }
}
Copy after login

Run one of the following:

go test -v
foo_api_key=bar go test -v
Copy after login

Use the built-in short flag

package main

import (
    "testing"
)

func testalways(t *testing.t) {
    // ...
}

func testsometimes(t *testing.t) {
    if testing.short() {
        t.skip("-short is set")
    }

    // ...
}
Copy after login

Run one of the following:

go test -v -short
go test -v
Copy after login

Use custom flags

package main

import (
    "flag"
    "testing"
)

var withfoo = false // or true to run test by default

func init() {
    flag.boolvar(&withfoo, "with-foo", withfoo, "include foo tests")
}

func testalways(t *testing.t) {
    // ...
}

func testsometimes(t *testing.t) {
    if !withfoo {
        t.skip("-with-foo is not set")
    }

    // ...
}
Copy after login

Run one of the following:

go test -v
go test -v -with-foo
Copy after login

Using Building Constraints

// main_test.go
package main

import (
    "testing"
)

func testalways(t *testing.t) {
    // ...
}
Copy after login
// foo_test.go
//go:build foo
package main

import (
    "testing"
)

func testsometimes(t *testing.t) {
    // ...
}
Copy after login

Run one of the following:

go test -v
go test -v -tags=foo
Copy after login

Please note that with build flags, the output will not indicate that the test has been skipped. A tagged .go file is invisible to the compiler unless the build flag is included on the command line (or in goflags).

The above is the detailed content of How to manage tests that require API keys. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template