2018-05-22 19:43:36 +00:00
|
|
|
// Copyright 2016-2018, Pulumi Corporation.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2017-06-14 16:44:58 +00:00
|
|
|
|
2018-05-15 22:28:00 +00:00
|
|
|
package logging
|
2017-06-14 16:44:58 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2020-03-25 22:57:46 +00:00
|
|
|
func TestInitLogging(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2020-03-25 22:57:46 +00:00
|
|
|
// Just ensure we can initialize logging (and reset it afterwards).
|
|
|
|
prevLog := LogToStderr
|
|
|
|
prevV := Verbose
|
|
|
|
prevFlow := LogFlow
|
|
|
|
InitLogging(true, 9, true)
|
|
|
|
InitLogging(prevLog, prevV, prevFlow)
|
|
|
|
assert.Equal(t, prevLog, LogToStderr)
|
|
|
|
assert.Equal(t, prevV, Verbose)
|
|
|
|
assert.Equal(t, prevFlow, LogFlow)
|
|
|
|
}
|
2018-05-15 23:09:15 +00:00
|
|
|
|
|
|
|
func TestFilter(t *testing.T) {
|
2022-03-04 08:17:41 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2018-05-15 23:09:15 +00:00
|
|
|
filter1 := CreateFilter([]string{"secret1", "secret2"}, "[secret]")
|
2023-02-10 19:13:40 +00:00
|
|
|
msg1 := filter1.Filter(
|
|
|
|
"These are my secrets: secret1, secret2, secret3, secret10")
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: [secret], [secret], secret3, [secret]0",
|
|
|
|
msg1)
|
2018-05-15 23:09:15 +00:00
|
|
|
|
2019-08-14 13:20:56 +00:00
|
|
|
// Ensure that special characters don't screw up the search
|
2018-05-15 23:09:15 +00:00
|
|
|
filter2 := CreateFilter([]string{"secret.*", "secre[t]3"}, "[creds]")
|
2023-02-10 19:13:40 +00:00
|
|
|
msg2 := filter2.Filter(
|
|
|
|
"These are my secrets: secret1, secret2, secret3, secret.*, secre[t]3")
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: secret1, secret2, secret3, [creds], [creds]",
|
|
|
|
msg2)
|
2019-08-13 11:04:58 +00:00
|
|
|
|
2019-08-14 13:20:56 +00:00
|
|
|
// Ensure that non-UTF8 characters don't screw up the search
|
|
|
|
filter3 := CreateFilter([]string{"nonutf8\xa7", "secret1"}, "[creds]")
|
2023-02-10 19:13:40 +00:00
|
|
|
msg3 := filter3.Filter(
|
|
|
|
"These are my secrets: secret1, nonutf8\xa7")
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: [creds], [creds]",
|
|
|
|
msg3)
|
2019-08-14 13:20:56 +00:00
|
|
|
|
|
|
|
// Short secrets of 1-2 characters are not masked
|
|
|
|
filter4 := CreateFilter([]string{"a", "my", "123"}, "[creds]")
|
2023-02-10 19:13:40 +00:00
|
|
|
msg4 := filter4.Filter(
|
|
|
|
"These are my secrets: a, my, 123")
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: a, my, [creds]",
|
|
|
|
msg4)
|
2023-02-10 18:55:08 +00:00
|
|
|
|
|
|
|
// Ensure that multi-line secrets are masked in output.
|
|
|
|
filter5 := CreateFilter([]string{"multi\nline\nsecret"}, "[secret]")
|
|
|
|
msg5 := filter5.Filter(
|
|
|
|
`These are my secrets: multi\nline\nsecret`)
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: [secret]",
|
|
|
|
msg5)
|
|
|
|
|
|
|
|
// Ensure that secrets with tabs are masked in output.
|
|
|
|
filter6 := CreateFilter([]string{"secretwith\t"}, "[secret]")
|
|
|
|
msg6 := filter6.Filter(
|
|
|
|
`These are my secrets: secretwith\t`)
|
|
|
|
assert.Equal(t,
|
|
|
|
"These are my secrets: [secret]",
|
|
|
|
msg6)
|
2018-05-15 23:09:15 +00:00
|
|
|
}
|