mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 05:45:46 +00:00
47d445d680
* [CONSUL-395] Update check_hostport and Usage (#40) * [CONSUL-397] Copy envoy binary from Image (#41) * [CONSUL-382] Support openssl in unique test dockerfile (#43) * [CONSUL-405] Add bats to single container (#44) * [CONSUL-414] Run Prometheus Test Cases and Validate Changes (#46) * [CONSUL-410] Run Jaeger in Single container (#45) * [CONSUL-412] Run test-sds-server in single container (#48) * [CONSUL-408] Clean containers (#47) * [CONSUL-384] Rebase and sync fork (#50) * [CONSUL-415] Create Scenarios Troubleshooting Docs (#49) * [CONSUL-417] Update Docs Single Container (#51) * [CONSUL-428] Add Socat to single container (#54) * [CONSUL-424] Replace pkill in kill_envoy function (#52) * [CONSUL-434] Modify Docker run functions in Helper script (#53) * [CONSUL-435] Replace docker run in set_ttl_check_state & wait_for_agent_service_register functions (#55) * [CONSUL-438] Add netcat (nc) in the Single container Dockerfile (#56) * [CONSUL-429] Replace Docker run with Docker exec (#57) * [CONSUL-436] Curl timeout and run tests (#58) * [CONSUL-443] Create dogstatsd Function (#59) * [CONSUL-431] Update Docs Netcat (#60) * [CONSUL-439] Parse nc Command in function (#61) * [CONSUL-463] Review curl Exec and get_ca_root Func (#63) * [CONSUL-453] Docker hostname in Helper functions (#64) * [CONSUL-461] Test wipe volumes without extra cont (#66) * [CONSUL-454] Check ports in the Server and Agent containers (#65) * [CONSUL-441] Update windows dockerfile with version (#62) * [CONSUL-466] Review case-grpc Failing Test (#67) * [CONSUL-494] Review case-cfg-resolver-svc-failover (#68) * [CONSUL-496] Replace docker_wget & docker_curl (#69) * [CONSUL-499] Cleanup Scripts - Remove nanoserver (#70) * [CONSUL-500] Update Troubleshooting Docs (#72) * [CONSUL-502] Pull & Tag Envoy Windows Image (#73) * [CONSUL-504] Replace docker run in docker_consul (#76) * [CONSUL-505] Change admin_bind * [CONSUL-399] Update envoy to 1.23.1 (#78) * [CONSUL-510] Support case-wanfed-gw on Windows (#79) * [CONSUL-506] Update troubleshooting Documentation (#80) * [CONSUL-512] Review debug_dump_volumes Function (#81) * [CONSUL-514] Add zipkin to Docker Image (#82) * [CONSUL-515] Update Documentation (#83) * [CONSUL-529] Support case-consul-exec (#86) * [CONSUL-530] Update Documentation (#87) * [CONSUL-530] Update default consul version 1.13.3 * [CONSUL-539] Cleanup (#91) * [CONSUL-546] Scripts Clean-up (#92) * [CONSUL-491] Support admin_access_log_path value for Windows (#71) * [CONSUL-519] Implement mkfifo Alternative (#84) * [CONSUL-542] Create OS Specific Files for Envoy Package (#88) * [CONSUL-543] Create exec_supported.go (#89) * [CONSUL-544] Test and Build Changes (#90) * Implement os.DevNull * using mmap instead of disk files * fix import in exec-unix * fix nmap open too many arguemtn * go fmt on file * changelog file * fix go mod * Update .changelog/17694.txt Co-authored-by: Dhia Ayachi <dhia@hashicorp.com> * different mmap library * fix bootstrap json * some fixes * chocolatey version fix and image fix * using different library * fix Map funciton call * fix mmap call * fix tcp dump * fix tcp dump * windows tcp dump * Fix docker run * fix tests * fix go mod * fix version 16.0 * fix version * fix version dev * sleep to debug * fix sleep * fix permission issue * fix permission issue * fix permission issue * fix command * fix command * fix funciton * fix assert config entry status command not found * fix command not found assert_cert_has_cn * fix command not found assert_upstream_missing * fix command not found assert_upstream_missing_once * fix command not found get_upstream_endpoint * fix command not found get_envoy_public_listener_once * fix command not found * fix test cases * windows integration test workflow github * made code similar to unix using npipe * fix go.mod * fix dialing of npipe * dont wait * check size of written json * fix undefined n * running * fix dep * fix syntax error * fix workflow file * windows runner * fix runner * fix from json * fix runs on * merge connect envoy * fix cin path * build * fix file name * fix file name * fix dev build * remove unwanted code * fix upload * fix bin name * fix path * checkout current branch * fix path * fix tests * fix shell bash for windows sh files * fix permission of run-test.sh * removed docker dev * added shell bash for tests * fix tag * fix win=true * fix cd * added dev * fix variable undefined * removed failing tests * fix tcp dump image * fix curl * fix curl * tcp dump path * fix tcpdump path * fix curl * fix curl install * stop removing intermediate containers * fix tcpdump docker image * revert -rm * --rm=false * makeing docker image before * fix tcpdump * removed case consul exec * removed terminating gateway simple * comment case wasm * removed data dog * comment out upload coverage * uncomment case-consul-exec * comment case consul exec * if always * logs * using consul 1.17.0 * fix quotes * revert quotes * redirect to dev null * Revert version * revert consul connect * fix version * removed envoy connect * not using function * change log * docker logs * fix logs * restructure bad authz * rmeoved dev null * output * fix file descriptor * fix cacert * fix cacert * fix ca cert * cacert does not work in windows curl * fix func * removed docker logs * added sleep * fix tls * commented case-consul-exec * removed echo * retry docker consul * fix upload bin * uncomment consul exec * copying consul.exe to docker image * copy fix * fix paths * fix path * github workspace path * latest version * Revert "latest version" This reverts commit 5a7d7b82d9e7553bcb01b02557ec8969f9deba1d. * commented consul exec * added ssl revoke best effort * revert best effort * removed unused files * rename var name and change dir * windows runner * permission * needs setup fix * swtich to github runner * fix file path * fix path * fix path * fix path * fix path * fix path * fix build paths * fix tag * nightly runs * added matrix in github workflow, renamed files * fix job * fix matrix * removed brackes * from json * without using job matrix * fix quotes * revert job matrix * fix workflow * fix comment * added comment * nightly runs * removed datadog ci as it is already measured in linux one * running test * Revert "running test" This reverts commit 7013d15a23732179d18ec5d17336e16b26fab5d4. * pr comment fixes * running test now * running subset of test * running subset of test * job matrix * shell bash * removed bash shell * linux machine for job matrix * fix output * added cat to debug * using ubuntu latest * fix job matrix * fix win true * fix go test * revert job matrix --------- Co-authored-by: Jose Ignacio Lorenzo <74208929+joselo85@users.noreply.github.com> Co-authored-by: Franco Bruno Lavayen <cocolavayen@gmail.com> Co-authored-by: Ivan K Berlot <ivanberlot@gmail.com> Co-authored-by: Ezequiel Fernández Ponce <20102608+ezfepo@users.noreply.github.com> Co-authored-by: joselo85 <joseignaciolorenzo85@gmail.com> Co-authored-by: Ezequiel Fernández Ponce <ezequiel.fernandez@southworks.com> Co-authored-by: Dhia Ayachi <dhia@hashicorp.com>
175 lines
3.3 KiB
Go
175 lines
3.3 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
//go:build integration
|
|
// +build integration
|
|
|
|
package envoy
|
|
|
|
import (
|
|
"flag"
|
|
"io/ioutil"
|
|
"log"
|
|
"os"
|
|
"os/exec"
|
|
"sort"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var (
|
|
flagWin = flag.Bool("win", false, "Execute tests on windows")
|
|
)
|
|
|
|
func TestEnvoy(t *testing.T) {
|
|
flag.Parse()
|
|
|
|
if *flagWin == true {
|
|
dir := "../../../"
|
|
check_dir_files(dir)
|
|
}
|
|
|
|
testcases, err := discoverCases()
|
|
require.NoError(t, err)
|
|
|
|
runCmd(t, "suite_setup")
|
|
|
|
defer runCmd(t, "suite_teardown")
|
|
|
|
for _, tc := range testcases {
|
|
t.Run(tc, func(t *testing.T) {
|
|
caseDir := "CASE_DIR=" + tc
|
|
|
|
t.Cleanup(func() {
|
|
if t.Failed() {
|
|
runCmd(t, "capture_logs", caseDir)
|
|
}
|
|
|
|
runCmd(t, "test_teardown", caseDir)
|
|
})
|
|
|
|
runCmd(t, "run_tests", caseDir)
|
|
})
|
|
}
|
|
}
|
|
|
|
|
|
func runCmdLinux(t *testing.T, c string, env ...string) {
|
|
t.Helper()
|
|
|
|
cmd := exec.Command("./run-tests.sh", c)
|
|
cmd.Env = append(os.Environ(), env...)
|
|
cmd.Stdout = os.Stdout
|
|
cmd.Stderr = os.Stderr
|
|
if err := cmd.Run(); err != nil {
|
|
t.Fatalf("command failed: %v", err)
|
|
}
|
|
}
|
|
|
|
func runCmdWindows(t *testing.T, c string, env ...string) {
|
|
t.Helper()
|
|
|
|
param_5 := "false"
|
|
if env != nil {
|
|
param_5 = strings.Join(env, " ")
|
|
}
|
|
|
|
cmd := exec.Command("cmd", "/C", "bash run-tests.windows.sh", c, param_5)
|
|
cmd.Env = append(os.Environ(), env...)
|
|
cmd.Stdout = os.Stdout
|
|
cmd.Stderr = os.Stderr
|
|
if err := cmd.Run(); err != nil {
|
|
t.Fatalf("command failed: %v", err)
|
|
}
|
|
}
|
|
|
|
func runCmd(t *testing.T, c string, env ...string) {
|
|
t.Helper()
|
|
|
|
if *flagWin == true {
|
|
runCmdWindows(t, c, env...)
|
|
|
|
} else {
|
|
runCmdLinux(t, c, env...)
|
|
}
|
|
}
|
|
|
|
// Discover the cases so we pick up both oss and ent copies.
|
|
func discoverCases() ([]string, error) {
|
|
cwd, err := os.Getwd()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
dirs, err := os.ReadDir(cwd)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var out []string
|
|
for _, fi := range dirs {
|
|
if fi.IsDir() && strings.HasPrefix(fi.Name(), "case-") {
|
|
out = append(out, fi.Name())
|
|
}
|
|
}
|
|
|
|
sort.Strings(out)
|
|
return out, nil
|
|
}
|
|
|
|
// CRLF convert functions
|
|
// Recursively iterates through the directory passed by parameter looking for the sh and bash files.
|
|
// Upon finding them, it calls crlf_file_check.
|
|
func check_dir_files(path string) {
|
|
files, err := ioutil.ReadDir(path)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
for _, fil := range files {
|
|
|
|
v := strings.Split(fil.Name(), ".")
|
|
file_extension := v[len(v)-1]
|
|
|
|
file_path := path + "/" + fil.Name()
|
|
|
|
if fil.IsDir() == true {
|
|
check_dir_files(file_path)
|
|
}
|
|
|
|
if file_extension == "sh" || file_extension == "bash" {
|
|
crlf_file_check(file_path)
|
|
}
|
|
}
|
|
}
|
|
|
|
// Check if a file contains CRLF line endings if so call crlf_normalize
|
|
func crlf_file_check(file_name string) {
|
|
|
|
file, err := ioutil.ReadFile(file_name)
|
|
text := string(file)
|
|
|
|
if edit := crlf_verify(text); edit != -1 {
|
|
crlf_normalize(file_name, text)
|
|
}
|
|
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
}
|
|
|
|
// Checks for the existence of CRLF line endings.
|
|
func crlf_verify(text string) int {
|
|
position := strings.Index(text, "\r\n")
|
|
return position
|
|
}
|
|
|
|
// Replace CRLF line endings with LF.
|
|
func crlf_normalize(filename, text string) {
|
|
text = strings.Replace(text, "\r\n", "\n", -1)
|
|
data := []byte(text)
|
|
|
|
ioutil.WriteFile(filename, data, 0644)
|
|
}
|