summaryrefslogtreecommitdiff
path: root/doc/development
diff options
context:
space:
mode:
authorNick Thomas <nick@gitlab.com>2018-10-19 03:09:37 +0100
committerNick Thomas <nick@gitlab.com>2018-10-19 03:09:37 +0100
commit2953798e7e57aecbceb2dcb3a9e0178d179336a5 (patch)
tree6129760bb0e20249ffb9c5f9d37ca9b155757671 /doc/development
parentc094bdb8206322eff5cdc6c22b9eafa08ff3bd2d (diff)
downloadgitlab-ce-2953798e7e57aecbceb2dcb3a9e0178d179336a5.tar.gz
Document the :repository and :custom_repo traits
Diffstat (limited to 'doc/development')
-rw-r--r--doc/development/testing_guide/best_practices.md31
1 files changed, 31 insertions, 0 deletions
diff --git a/doc/development/testing_guide/best_practices.md b/doc/development/testing_guide/best_practices.md
index acbfa1850b4..04e9dc648c3 100644
--- a/doc/development/testing_guide/best_practices.md
+++ b/doc/development/testing_guide/best_practices.md
@@ -348,6 +348,37 @@ GitLab uses [factory_bot] as a test fixture replacement.
All fixtures should be be placed under `spec/fixtures/`.
+### Repositories
+
+Testing some functionality, e.g., merging a merge request, requires a git
+repository with a certain state to be present in the test environment. GitLab
+maintains the [gitlab-test](https://gitlab.com/gitlab-org/gitlab-test)
+repository for certain common cases - you can ensure a copy of the repository is
+used with the `:repository` trait for project factories:
+
+```ruby
+let(:project) { create(:project, :repository) }
+```
+
+Where you can, consider using the `:custom_repo` trait instead of `:repository`.
+This allows you to specify exactly what files will appear in the `master` branch
+of the project's repository. For example:
+
+```ruby
+let(:project) do
+ create(
+ :project, :custom_repo,
+ files: {
+ 'README.md' => 'Content here',
+ 'foo/bar/baz.txt' => 'More content here'
+ }
+ )
+end
+```
+
+This will create a repository containing two files, with default permissions and
+the specified content.
+
### Config
RSpec config files are files that change the RSpec config (i.e.