Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: increase unit test coverage #23

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

valeriiashapoval
Copy link
Contributor

@valeriiashapoval valeriiashapoval commented Mar 10, 2023

Those tests cover 75.2% of the proxy: api package (65.5%) and pkg (78.9%).

)

var (
OIDCNotEnabled = false
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we move the package-level variables to the method they are used?

This will avoid polluting the package namespace.
In general variables should be declared with the minimum scope needed.

var (
OIDCNotEnabled = false
OIDCIsEnabled = true
emptyFIlename = ""
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

typo here

OIDCConfigFilename = "./secrets/oidc-config.yaml.sample"
)

func TestOIDCConfig_Validate(t *testing.T) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As mentioned in https://github.com/bf2fc6cc711aee1a0c2a/observability-remote-write-proxy/pull/12#discussion_r1114172741 Validate should be reserved to validation and reading of the file should be decoupled from it to make it more testable

)

var (
rw = &prometheus.WriteRequest{
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@@ -58,6 +59,13 @@ var (
req = &prometheus.WriteRequest{
Timeseries: []*prometheus.TimeSeries{},
}
metadataReq = &prometheus.WriteRequest{
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

},
want: true,
},
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should also test that if a remote write request has both timeseries data and metadata data then the request is not a metadata request

@valeriiashapoval valeriiashapoval changed the title WIP: test: increase unit test coverage test: increase unit test coverage Mar 27, 2023
@valeriiashapoval
Copy link
Contributor Author

thanks @miguelsorianod @pb82 ! forgot to add replies - the comments have been addressed in the latest commits.

)

func TestOIDCConfig_Validate(t *testing.T) {
OIDCNotEnabled := false
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instead of creating the OIDCNotEnabled, OIDCIsEnabled the boolean values can just be set directly in the fields struct directly changing the Enabled attribute to be a bool instead of *bool.

Then in the loop you can just pass the address of it, or create a copy in the loop itself and then passing the address to the method call in the loop

OIDCNotEnabled := false
OIDCIsEnabled := true
emptyFilename := ""
filenameThatDoesntExist := "doesnt-exist.yaml"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A better alternative that doesn't require setting up the files all at the beginning is to add have an attribute in the fields struct that is of type func() string that returns the file name. In that function you would add the logic to create the file and such and then return the name of the filename.

Then on the loop you would call that function and from the returned result you would also perform a deferred call to os.Remove using that returned file name to perform the cleanup

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also remember my #23 (comment) comment. The reason this test is this complicated is because the file reading is coupled to the validation. This should be improved, but that can be dealt with in another PR.

)

var (
a byte = 116
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As mentioned in other comments we should avoid the use of global variables. Can we moved them where needed?

wantErr bool
}{
{
name: "should return an error",
Copy link
Contributor

@miguelsorianod miguelsorianod Apr 13, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why should creating a new default token verifier return an error?

want bool
}{
{
name: "should return true",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The description should be more descriptive. For example: When the token verifier enabled option is true the token verifier is enabled

want: true,
},
{
name: "should return false",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

want string
}{
{
name: "should return token",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See https://github.com/bf2fc6cc711aee1a0c2a/observability-remote-write-proxy/pull/23/files#r1165345194. Some of the test names should be more descriptive. Instead of telling what it returns it should explain in the form "when/if this happens this is the outcome" or similarly

wantErr bool
}{
{
name: "should return error",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

wantErr bool
}{
{
name: "should return error",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This only tests an error. We should have a case for successful validation too

wantErr: false,
},
{
name: "should return error",
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

}

func TestIsMetadataRequest(t *testing.T) {
metadataReq := &prometheus.WriteRequest{
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there some reason the variables have been created first? Can we do the same but in each args value?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants