Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
b31d6012
Commit
b31d6012
authored
Mar 28, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
32e33216
ed99dafc
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
32 additions
and
20 deletions
+32
-20
doc/development/testing_guide/best_practices.md
doc/development/testing_guide/best_practices.md
+15
-0
doc/development/testing_guide/index.md
doc/development/testing_guide/index.md
+1
-1
doc/topics/autodevops/index.md
doc/topics/autodevops/index.md
+4
-5
doc/user/project/clusters/index.md
doc/user/project/clusters/index.md
+12
-14
No files found.
doc/development/testing_guide/best_practices.md
View file @
b31d6012
# Testing best practices
# Testing best practices
## Test Design
Testing at GitLab is a first class citizen, not an afterthought. It's important we consider the design of our tests
as we do the design of our features.
When implementing a feature, we think about developing the right capabilities the right way, which helps us
narrow our scope to a manageable level. When implementing tests for a feature, we must think about developing
the right tests, but then cover _all_ the important ways the test may fail, which can quickly widen our scope to
a level that is difficult to manage.
Test heuristics can help solve this problem. They concisely address many of the common ways bugs
manifest themselves within our code. When designing our tests, take time to review known test heuristics to inform
our test design. We can find some helpful heuristics documented in the Handbook in the
[
Test Design
](
https://about.gitlab.com/handbook/engineering/quality/guidelines/test-engineering/test-design/
)
section.
## Test speed
## Test speed
GitLab has a massive test suite that, without [parallelization], can take hours
GitLab has a massive test suite that, without [parallelization], can take hours
...
...
doc/development/testing_guide/index.md
View file @
b31d6012
...
@@ -33,7 +33,7 @@ changes should be tested.
...
@@ -33,7 +33,7 @@ changes should be tested.
## [Testing best practices](best_practices.md)
## [Testing best practices](best_practices.md)
Everything you should know about how to write good tests: RSpec, FactoryBot,
Everything you should know about how to write good tests:
Test Design,
RSpec, FactoryBot,
system tests, parameterized tests etc.
system tests, parameterized tests etc.
---
---
...
...
doc/topics/autodevops/index.md
View file @
b31d6012
...
@@ -1022,10 +1022,9 @@ planned for a subsequent release.
...
@@ -1022,10 +1022,9 @@ planned for a subsequent release.
buildpack
](
#custom-buildpacks
)
.
buildpack
](
#custom-buildpacks
)
.
-
Auto Test may fail because of a mismatch between testing frameworks. In this
-
Auto Test may fail because of a mismatch between testing frameworks. In this
case, you may need to customize your
`.gitlab-ci.yml`
with your test commands.
case, you may need to customize your
`.gitlab-ci.yml`
with your test commands.
-
Auto Deploy may fail if it is unable to create a Kubernetes namespace and
-
Auto Deploy will fail if GitLab can not create a Kubernetes namespace and
service account for your project. See the
service account for your project. For help debugging this issue, see
[
troubleshooting failed deployments
](
../../user/project/clusters/index.md#troubleshooting-failed-deployment-jobs
)
[
Troubleshooting failed deployment jobs
](
../../user/project/clusters/index.md#troubleshooting-failed-deployment-jobs
)
.
section to debug why these resources were not created.
### Disable the banner instance wide
### Disable the banner instance wide
...
...
doc/user/project/clusters/index.md
View file @
b31d6012
...
@@ -548,25 +548,23 @@ service account of the cluster integration.
...
@@ -548,25 +548,23 @@ service account of the cluster integration.
### Troubleshooting failed deployment jobs
### Troubleshooting failed deployment jobs
GitLab will create a namespace and service account specifically for your
GitLab will create a namespace and service account specifically for your
deployment jobs. These resources are created just before the deployment
deployment jobs, immediately before the jobs starts.
job starts. Sometimes there may be errors that cause their creation to fail.
In such instances, your job will fail with the message:
However, sometimes GitLab can not create them.
In such instances, your job will fail with the message:
```
The job failed to complete prerequisite tasks```
```
text
The job failed to complete prerequisite tasks
```
You will need to check the [logs](../../../administration/logs.md) to debug
To find the cause of this error when creating a namespace and service account, check the
[
logs
](
../../../administration/logs.md#sidekiqlog
)
.
why the namespace and service account creation failed.
A common reason for failure is that the token you gave GitLab did not have
Common reasons for failure include:
[`cluster-admin`](https://kubernetes.io/docs/reference/access-authn-authz/rbac/#user-facing-roles)
privileges as GitLab expects.
Another common problem is caused by a missing `KUBECONFIG` or `KUBE_TOKEN`.
-
The token you gave GitLab did not have
[
`cluster-admin`
](
https://kubernetes.io/docs/reference/access-authn-authz/rbac/#user-facing-roles
)
To be passed to your job, it must have a matching
privileges required by GitLab.
[`environment:name`](../../../ci/environments.md#defining-environments). If
-
Missing
`KUBECONFIG`
or
`KUBE_TOKEN`
variables. To be passed to your job, they must have a matching
your job has no `environment:name` set, it will not be passed the Kubernetes
[
`environment:name`
](
../../../ci/environments.md#defining-environments
)
. If your job has no
credentials.
`environment:name`
set, it will not be passed the Kubernetes
credentials.
## Monitoring your Kubernetes cluster **[ULTIMATE]**
## Monitoring your Kubernetes cluster **[ULTIMATE]**
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment