This repository has been archived by the owner on Apr 7, 2020. It is now read-only.
forked from istio/istio
/
apps.go
83 lines (69 loc) · 2.62 KB
/
apps.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
// Copyright 2018 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 components
import (
"net/http"
"testing"
"istio.io/istio/pilot/pkg/model"
"istio.io/istio/pkg/test/application/echo"
"istio.io/istio/pkg/test/framework/api/component"
"istio.io/istio/pkg/test/framework/api/ids"
)
// AppProtocol enumerates the protocol options for calling an DeployedAppEndpoint endpoint.
type AppProtocol string
const (
// AppProtocolHTTP calls the app with HTTP
AppProtocolHTTP = "http"
// AppProtocolGRPC calls the app with GRPC
AppProtocolGRPC = "grpc"
// AppProtocolWebSocket calls the app with WebSocket
AppProtocolWebSocket = "ws"
)
// Apps is a component that provides access to all deployed test services.
type Apps interface {
component.Instance
GetApp(name string) (App, error)
GetAppOrFail(name string, t testing.TB) App
}
// App represents a deployed fake App within the mesh.
type App interface {
Name() string
Endpoints() []AppEndpoint
EndpointsForProtocol(protocol model.Protocol) []AppEndpoint
Call(e AppEndpoint, opts AppCallOptions) ([]*echo.ParsedResponse, error)
CallOrFail(e AppEndpoint, opts AppCallOptions, t testing.TB) []*echo.ParsedResponse
}
// AppCallOptions defines options for calling a DeployedAppEndpoint.
type AppCallOptions struct {
// Secure indicates whether a secure connection should be established to the endpoint.
Secure bool
// Protocol indicates the protocol to be used.
Protocol AppProtocol
// UseShortHostname indicates whether shortened hostnames should be used. This may be ignored by the environment.
UseShortHostname bool
// Count indicates the number of exchanges that should be made with the service endpoint. If not set (i.e. 0), defaults to 1.
Count int
// Headers indicates headers that should be sent in the request. Ingnored for WebSocket calls.
Headers http.Header
}
// AppEndpoint represents a single endpoint in a DeployedApp.
type AppEndpoint interface {
Name() string
Owner() App
Protocol() model.Protocol
}
// GetApps from the repository
func GetApps(e component.Repository, t testing.TB) Apps {
return e.GetComponentOrFail("", ids.Apps, t).(Apps)
}