istio.io/tests/setup
Craig Box c6e477a54c
Fix ambient doc tests (#15500)
* snip_annotate_bookinfo_gateway

* disable shellcheck

* Update content/en/docs/ambient/usage/extend-waypoint-wasm/index.md

Co-authored-by: Ben Leggett <854255+bleggett@users.noreply.github.com>

* Update content/en/docs/ambient/usage/extend-waypoint-wasm/index.md

grrr, I remember seeing that

Co-authored-by: Daniel Hawton <daniel@hawton.org>

---------

Co-authored-by: Ben Leggett <854255+bleggett@users.noreply.github.com>
Co-authored-by: Daniel Hawton <daniel@hawton.org>
2024-07-31 18:13:06 -04:00
..
dualstack Add docs test for dual-stack support (#14257) 2023-12-06 01:56:48 -08:00
multicluster Fix lint errors with new build tools (#11679) 2022-08-03 14:09:23 -07:00
profile-ambient Add ambient profile for docs test (#15210) 2024-06-02 06:57:04 -04:00
profile-default gateway-api: doc tests should not run with alpha CRDs by default (#13782) 2023-08-30 17:15:08 -07:00
profile-demo gateway-api: doc tests should not run with alpha CRDs by default (#13782) 2023-08-30 17:15:08 -07:00
profile-minimal gateway-api: doc tests should not run with alpha CRDs by default (#13782) 2023-08-30 17:15:08 -07:00
profile-none Updated job names as they cannot use an underscore (#13409) 2023-06-19 12:16:09 -07:00
README.md Fix ambient doc tests (#15500) 2024-07-31 18:13:06 -04:00

README.md

Setup Configs for istio.io Doc Tests

Each folder under tests/setup corresponds to an Istio setup configuration. Currently supported setup configurations include:

  • profile_ambient to install the ambient profile
  • profile_default to install the default profile
  • profile_demo to install the demo profile
  • profile_minimal to install the minimal profile
  • profile_none to not install istio at all.

Adding a Setup Config

To add a setup configuration, create a new go file tests/setup/<your_config_name>/doc_test.go using the following template. Two modifications are required.

// Copyright Istio Authors
//
// 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.
package setupconfig

import (
	"os"
	"testing"

	"istio.io/istio.io/pkg/test/istioio"
	"istio.io/istio/pkg/test/framework"
	"istio.io/istio/pkg/test/framework/components/istio"
)

var (
	inst      istio.Instance
	setupSpec = "profile=demo" // this is to appear in test scripts following '# @setup'
)

func TestMain(m *testing.M) {
	if !istioio.NeedSetup(setupSpec) {
		os.Exit(0)
	}

	framework.
		NewSuite(m).
		Setup(istio.Setup(&inst, setupConfig)).
		Run()
}

func TestDocs(t *testing.T) {
	istioio.TestDocs(t, setupSpec)
}

func setupConfig(cfg *istio.Config) {
	// specify what your config requires
}