Documentation ¶
Overview ¶
Package workertest provides a framework for declarative definition of worker integration tests.
Index ¶
- func AnyArtifact() func(t *testing.T, a Artifact)
- func ErrorArtifact() func(t *testing.T, a Artifact)
- func GrepArtifact(substring string) func(t *testing.T, a Artifact)
- func LogArtifact() func(t *testing.T, a Artifact)
- func MatchArtifact(body, contentType string) func(t *testing.T, a Artifact)
- func ReferenceArtifact() func(t *testing.T, a Artifact)
- func S3Artifact() func(t *testing.T, a Artifact)
- type Artifact
- type ArtifactAssertions
- type Case
- type StatusAssertion
- type Task
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AnyArtifact ¶
AnyArtifact creates an assertion that checks matches anything.
func ErrorArtifact ¶
ErrorArtifact creates an assertion that holds if the artifact is an error artifact
func GrepArtifact ¶
GrepArtifact creates an assertion that holds if the artifact contains the given substring.
func LogArtifact ¶ added in v0.1.1
LogArtifact creates an assetion that logs the artifact, to test log. This is mostly useful when developing integration tests.
func MatchArtifact ¶ added in v0.1.1
MatchArtifact creates an assertion that holds if the artifact body matches given body and has the given contentType
func ReferenceArtifact ¶
ReferenceArtifact creates an assertion that holds if the artifact is a reference artifact
func S3Artifact ¶
S3Artifact creates an assertion that holds if the artifact is an S3 artifact
Types ¶
type Artifact ¶
type Artifact struct { ContentType string Expires time.Time Name string StorageType string Data []byte ContentEncoding string }
Artifact contains artifact meta-data.
type ArtifactAssertions ¶
An ArtifactAssertions is a mapping from artifact name to assertion for the artifact. If mapping to nil value, any artifact will be permitted.
type Case ¶
type Case struct { Engine string // Engine to be used EngineConfig string // Engine configuration as JSON PluginConfig string // Configuration of plugins, see plugins.PluginManagerConfigSchema() Tasks []Task // Tasks to create and associated assertions Concurrency int // Worker concurrency, if zero defaulted to 1 and tasks will sequantially dependent StoppedGracefully bool // True, if worker is expected to stop gracefully StoppedNow bool // True, if worker is expected to stop now Timeout time.Duration // Test timeout, defaults to 10 min }
Case is a worker test case
func (Case) TestWithFakeQueue ¶
TestWithFakeQueue runs integration tests against FakeQueue
func (Case) TestWithRealQueue ¶
TestWithRealQueue runs integration tests against production queue
type StatusAssertion ¶
A StatusAssertion is a function that can make an assertion on a task status
type Task ¶
type Task struct { Title string // Optional title (for debugging) Payload string // Task payload as JSON Success bool // True, if task should be successfully Exception runtime.ExceptionReason // Reason, if exception is expected Artifacts ArtifactAssertions // Mapping from artifact name to assertion AllowAdditional bool // True, if additional artifacts is allowed Status StatusAssertion // Optional, custom assertion on status and queue }
A Task to be included in a worker test case
Directories ¶
Path | Synopsis |
---|---|
Package fakequeue provides a fake implementation of taskcluster-queue in golang, The FakeQueue server stores tasks in-memory, it doesn't validate authentication, but implements most end-points correctly.
|
Package fakequeue provides a fake implementation of taskcluster-queue in golang, The FakeQueue server stores tasks in-memory, it doesn't validate authentication, but implements most end-points correctly. |