forked from knative/eventing
-
Notifications
You must be signed in to change notification settings - Fork 7
/
config.go
53 lines (43 loc) · 1.73 KB
/
config.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
/*
Copyright 2019 The Knative 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 common
import (
"github.com/knative/eventing/test/base/resources"
)
// DefaultChannel is the default channel we will run tests against.
const DefaultChannel = resources.InMemoryChannelKind
// ValidChannelsMap saves the channel-features mapping.
// Each pair means the channel support the list of features.
var ValidChannelsMap = map[string]ChannelConfig{
resources.InMemoryChannelKind: {
Features: []Feature{FeatureBasic},
},
resources.NatssChannelKind: {
Features: []Feature{FeatureBasic, FeatureRedelivery, FeaturePersistence},
},
}
// ChannelConfig includes general configuration for a channel.
type ChannelConfig struct {
Features []Feature
}
// Feature is the feature supported by the channel.
type Feature string
const (
// FeatureBasic is the feature that should be supported by all channels.
FeatureBasic Feature = "basic"
// FeatureRedelivery means if downstream rejects an event, that request will be attempted again.
FeatureRedelivery Feature = "redelivery"
// FeaturePersistence means if channel's Pod goes down, all events already ACKed by the channel
// will persist and be retransmitted when the Pod restarts.
FeaturePersistence Feature = "persistence"
)