Commit c04bdf22 authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab master

parents 288c393c eff83fc9
...@@ -557,6 +557,14 @@ export default { ...@@ -557,6 +557,14 @@ export default {
v-if="shouldShowMergeControls" v-if="shouldShowMergeControls"
class="gl-display-flex gl-align-items-center gl-flex-wrap" class="gl-display-flex gl-align-items-center gl-flex-wrap"
> >
<merge-train-helper-icon
v-if="shouldRenderMergeTrainHelperIcon"
:merge-train-when-pipeline-succeeds-docs-path="
mr.mergeTrainWhenPipelineSucceedsDocsPath
"
class="gl-mx-3"
/>
<gl-form-checkbox <gl-form-checkbox
v-if="canRemoveSourceBranch" v-if="canRemoveSourceBranch"
id="remove-source-branch-input" id="remove-source-branch-input"
...@@ -575,13 +583,6 @@ export default { ...@@ -575,13 +583,6 @@ export default {
:is-disabled="isSquashReadOnly" :is-disabled="isSquashReadOnly"
class="gl-mx-3" class="gl-mx-3"
/> />
<merge-train-helper-icon
v-if="shouldRenderMergeTrainHelperIcon"
:merge-train-when-pipeline-succeeds-docs-path="
mr.mergeTrainWhenPipelineSucceedsDocsPath
"
/>
</div> </div>
<template v-else> <template v-else>
<div class="bold js-resolve-mr-widget-items-message gl-ml-3"> <div class="bold js-resolve-mr-widget-items-message gl-ml-3">
......
...@@ -81,7 +81,8 @@ microservice_a: ...@@ -81,7 +81,8 @@ microservice_a:
trigger: trigger:
include: include:
- project: 'my-group/my-pipeline-library' - project: 'my-group/my-pipeline-library'
file: 'path/to/ci-config.yml' ref: 'main'
file: '/path/to/child-pipeline.yml'
``` ```
The maximum number of entries that are accepted for `trigger:include:` is three. The maximum number of entries that are accepted for `trigger:include:` is three.
...@@ -98,7 +99,7 @@ microservice_a: ...@@ -98,7 +99,7 @@ microservice_a:
strategy: depend strategy: depend
``` ```
## Merge Request child pipelines ## Merge request child pipelines
To trigger a child pipeline as a [Merge Request Pipeline](merge_request_pipelines.md) we need to: To trigger a child pipeline as a [Merge Request Pipeline](merge_request_pipelines.md) we need to:
...@@ -149,7 +150,7 @@ microservice_a: ...@@ -149,7 +150,7 @@ microservice_a:
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/35632) in GitLab 12.9. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/35632) in GitLab 12.9.
Instead of running a child pipeline from a static YAML file, you can define a job that runs Instead of running a child pipeline from a static YAML file, you can define a job that runs
your own script to generate a YAML file, which is then [used to trigger a child pipeline](../yaml/index.md#trigger-child-pipeline-with-generated-configuration-file). your own script to generate a YAML file, which is then used to trigger a child pipeline.
This technique can be very powerful in generating pipelines targeting content that changed or to This technique can be very powerful in generating pipelines targeting content that changed or to
build a matrix of targets and architectures. build a matrix of targets and architectures.
...@@ -171,6 +172,31 @@ configuration for jobs, like scripts, that use the Windows runner would use `\`. ...@@ -171,6 +172,31 @@ configuration for jobs, like scripts, that use the Windows runner would use `\`.
In GitLab 12.9, the child pipeline could fail to be created in certain cases, causing the parent pipeline to fail. In GitLab 12.9, the child pipeline could fail to be created in certain cases, causing the parent pipeline to fail.
This is [resolved](https://gitlab.com/gitlab-org/gitlab/-/issues/209070) in GitLab 12.10. This is [resolved](https://gitlab.com/gitlab-org/gitlab/-/issues/209070) in GitLab 12.10.
### Dynamic child pipeline example
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/35632) in GitLab 12.9.
You can trigger a child pipeline from a [dynamically generated configuration file](../pipelines/parent_child_pipelines.md#dynamic-child-pipelines):
```yaml
generate-config:
stage: build
script: generate-ci-config > generated-config.yml
artifacts:
paths:
- generated-config.yml
child-pipeline:
stage: test
trigger:
include:
- artifact: generated-config.yml
job: generate-config
```
The `generated-config.yml` is extracted from the artifacts and used as the configuration
for triggering the child pipeline.
## Nested child pipelines ## Nested child pipelines
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29651) in GitLab 13.4. > - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29651) in GitLab 13.4.
......
...@@ -177,7 +177,7 @@ deploy: ...@@ -177,7 +177,7 @@ deploy:
``` ```
In a parent pipeline, it runs the `test` job that subsequently runs a child pipeline, In a parent pipeline, it runs the `test` job that subsequently runs a child pipeline,
and the [`strategy: depend` option](../yaml/index.md#linking-pipelines-with-triggerstrategy) makes the `test` job wait until the child pipeline has finished. and the [`strategy: depend` option](../yaml/index.md#triggerstrategy) makes the `test` job wait until the child pipeline has finished.
The parent pipeline runs the `deploy` job in the next stage, that requires a resource from the `production` resource group. The parent pipeline runs the `deploy` job in the next stage, that requires a resource from the `production` resource group.
If the process mode is `oldest_first`, it executes the jobs from the oldest pipelines, meaning the `deploy` job is going to be executed next. If the process mode is `oldest_first`, it executes the jobs from the oldest pipelines, meaning the `deploy` job is going to be executed next.
......
...@@ -113,6 +113,9 @@ This means that whenever a new tag is pushed on project A, the job runs and the ...@@ -113,6 +113,9 @@ This means that whenever a new tag is pushed on project A, the job runs and the
`stage: deploy` ensures that this job runs only after all jobs with `stage: deploy` ensures that this job runs only after all jobs with
`stage: test` complete successfully. `stage: test` complete successfully.
NOTE:
You [cannot use the API to start `when:manual` trigger jobs](https://gitlab.com/gitlab-org/gitlab/-/issues/284086).
## Triggering a pipeline from a webhook ## Triggering a pipeline from a webhook
To trigger a job from a webhook of another project you need to add the following To trigger a job from a webhook of another project you need to add the following
......
...@@ -3802,31 +3802,19 @@ deploystacks: ...@@ -3802,31 +3802,19 @@ deploystacks:
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/8997) in GitLab Premium 11.8. > - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/8997) in GitLab Premium 11.8.
> - [Moved](https://gitlab.com/gitlab-org/gitlab/-/issues/199224) to GitLab Free in 12.8. > - [Moved](https://gitlab.com/gitlab-org/gitlab/-/issues/199224) to GitLab Free in 12.8.
Use `trigger` to define a downstream pipeline trigger. When GitLab starts a `trigger` job, Use `trigger` to start a downstream pipeline that is either:
a downstream pipeline is created.
Jobs with `trigger` can only use a [limited set of keywords](../pipelines/multi_project_pipelines.md#define-multi-project-pipelines-in-your-gitlab-ciyml-file). - [A multi-project pipeline](../pipelines/multi_project_pipelines.md).
For example, you can't run commands with [`script`](#script), [`before_script`](#before_script), - [A child pipeline](../pipelines/parent_child_pipelines.md).
or [`after_script`](#after_script).
You can use this keyword to create two different types of downstream pipelines: **Keyword type**: Job keyword. You can use it only as part of a job.
- [Multi-project pipelines](../pipelines/multi_project_pipelines.md#define-multi-project-pipelines-in-your-gitlab-ciyml-file)
- [Child pipelines](../pipelines/parent_child_pipelines.md)
In [GitLab 13.2 and later](https://gitlab.com/gitlab-org/gitlab/-/issues/197140/), you can
view which job triggered a downstream pipeline. In the [pipeline graph](../pipelines/index.md#visualize-pipelines),
hover over the downstream pipeline job.
In [GitLab 13.5 and later](https://gitlab.com/gitlab-org/gitlab/-/issues/201938), you **Possible inputs**:
can use [`when:manual`](#when) in the same job as `trigger`. In GitLab 13.4 and
earlier, using them together causes the error `jobs:#{job-name} when should be on_success, on_failure or always`.
You [cannot start `manual` trigger jobs with the API](https://gitlab.com/gitlab-org/gitlab/-/issues/284086).
#### Basic `trigger` syntax for multi-project pipelines - For multi-project pipelines, path to the downstream project.
- For child pipelines, path to the child pipeline CI/CD configuration file.
You can configure a downstream trigger by using the `trigger` keyword **Example of `trigger` for multi-project pipeline**:
with a full path to a downstream project:
```yaml ```yaml
rspec: rspec:
...@@ -3838,47 +3826,7 @@ staging: ...@@ -3838,47 +3826,7 @@ staging:
trigger: my/deployment trigger: my/deployment
``` ```
#### Complex `trigger` syntax for multi-project pipelines **Example of `trigger` for child pipelines**:
You can configure a branch name that GitLab uses to create
a downstream pipeline with:
```yaml
rspec:
stage: test
script: bundle exec rspec
staging:
stage: deploy
trigger:
project: my/deployment
branch: stable
```
To mirror the status from a triggered pipeline:
```yaml
trigger_job:
trigger:
project: my/project
strategy: depend
```
To mirror the status from an upstream pipeline:
```yaml
upstream_bridge:
stage: test
needs:
pipeline: other/project
```
#### `trigger` syntax for child pipeline
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/16094) in GitLab 12.7.
To create a [child pipeline](../pipelines/parent_child_pipelines.md), specify the path to the
YAML file that contains the configuration of the child pipeline:
```yaml ```yaml
trigger_job: trigger_job:
...@@ -3886,71 +3834,36 @@ trigger_job: ...@@ -3886,71 +3834,36 @@ trigger_job:
include: path/to/child-pipeline.yml include: path/to/child-pipeline.yml
``` ```
Similar to [multi-project pipelines](../pipelines/multi_project_pipelines.md#mirror-status-of-a-triggered-pipeline-in-the-trigger-job), **Additional details**:
it's possible to mirror the status from a triggered pipeline:
```yaml
trigger_job:
trigger:
include:
- local: path/to/child-pipeline.yml
strategy: depend
```
##### Trigger child pipeline with generated configuration file
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/35632) in GitLab 12.9.
You can also trigger a child pipeline from a [dynamically generated configuration file](../pipelines/parent_child_pipelines.md#dynamic-child-pipelines):
```yaml
generate-config:
stage: build
script: generate-ci-config > generated-config.yml
artifacts:
paths:
- generated-config.yml
child-pipeline:
stage: test
trigger:
include:
- artifact: generated-config.yml
job: generate-config
```
The `generated-config.yml` is extracted from the artifacts and used as the configuration - Jobs with `trigger` can only use a [limited set of keywords](../pipelines/multi_project_pipelines.md#define-multi-project-pipelines-in-your-gitlab-ciyml-file).
for triggering the child pipeline. For example, you can't run commands with [`script`](#script), [`before_script`](#before_script),
or [`after_script`](#after_script).
- In [GitLab 13.5 and later](https://gitlab.com/gitlab-org/gitlab/-/issues/201938), you
can use [`when:manual`](#when) in the same job as `trigger`. In GitLab 13.4 and
earlier, using them together causes the error `jobs:#{job-name} when should be on_success, on_failure or always`.
- In [GitLab 13.2 and later](https://gitlab.com/gitlab-org/gitlab/-/issues/197140/), you can
view which job triggered a downstream pipeline in the [pipeline graph](../pipelines/index.md#visualize-pipelines).
##### Trigger child pipeline with files from another project **Related topics**:
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/205157) in GitLab 13.5. - [Multi-project pipeline configuration examples](../pipelines/multi_project_pipelines.md#define-multi-project-pipelines-in-your-gitlab-ciyml-file).
- [Child pipeline configuration examples](../pipelines/parent_child_pipelines.md#examples).
- To force a rebuild of a specific branch, tag, or commit, you can
[use an API call with a trigger token](../triggers/index.md).
The trigger token is different than the `trigger` keyword.
To trigger child pipelines with files from another private project under the same #### `trigger:strategy`
GitLab instance, use [`include:file`](#includefile):
```yaml Use `trigger:strategy` to force the `trigger` job to wait for the downstream pipeline to complete
child-pipeline: before it is marked as **success**.
trigger:
include:
- project: 'my-group/my-pipeline-library'
ref: 'main'
file: '/path/to/child-pipeline.yml'
```
#### Linking pipelines with `trigger:strategy`
By default, the `trigger` job completes with the `success` status This behavior is different than the default, which is for the `trigger` job to be marked as
as soon as the downstream pipeline is created. **success** as soon as the downstream pipeline is created.
To force the `trigger` job to wait for the downstream (multi-project or child) pipeline to complete, use This setting makes your pipeline execution linear rather than parallel.
`strategy: depend`. This setting makes the trigger job wait with a "running" status until the triggered
pipeline completes. At that point, the `trigger` job completes and displays the same status as
the downstream job.
This setting can help keep your pipeline execution linear. In the following example, jobs from **Example of `trigger:strategy`**:
subsequent stages wait for the triggered pipeline to successfully complete before
starting, which reduces parallelization.
```yaml ```yaml
trigger_job: trigger_job:
...@@ -3959,14 +3872,8 @@ trigger_job: ...@@ -3959,14 +3872,8 @@ trigger_job:
strategy: depend strategy: depend
``` ```
#### Trigger a pipeline by API call In this example, jobs from subsequent stages wait for the triggered pipeline to
successfully complete before starting.
To force a rebuild of a specific branch, tag, or commit, you can use an API call
with a trigger token.
The trigger token is different than the [`trigger`](#trigger) keyword.
[Read more in the triggers documentation.](../triggers/index.md)
### `interruptible` ### `interruptible`
...@@ -4109,7 +4016,7 @@ deployment: ...@@ -4109,7 +4016,7 @@ deployment:
script: echo "Deploying..." script: echo "Deploying..."
``` ```
You must define [`strategy: depend`](#linking-pipelines-with-triggerstrategy) You must define [`strategy: depend`](#triggerstrategy)
with the `trigger` keyword. This ensures that the lock isn't released until the downstream pipeline with the `trigger` keyword. This ensures that the lock isn't released until the downstream pipeline
finishes. finishes.
......
...@@ -234,54 +234,65 @@ Migration tests depend on what the migration does exactly, the most common types ...@@ -234,54 +234,65 @@ Migration tests depend on what the migration does exactly, the most common types
#### Example of a data migration test #### Example of a data migration test
This spec tests the This spec tests the
[`db/post_migrate/20170526185842_migrate_pipeline_stages.rb`](https://gitlab.com/gitlab-org/gitlab-foss/blob/v11.6.5/db/post_migrate/20170526185842_migrate_pipeline_stages.rb) [`db/post_migrate/20200723040950_migrate_incident_issues_to_incident_type.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/db/post_migrate/20200723040950_migrate_incident_issues_to_incident_type.rb)
migration. You can find the complete spec in migration. You can find the complete spec in
[`spec/migrations/migrate_pipeline_stages_spec.rb`](https://gitlab.com/gitlab-org/gitlab-foss/blob/v11.6.5/spec/migrations/migrate_pipeline_stages_spec.rb). [`spec/migrations/migrate_incident_issues_to_incident_type_spec.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/spec/migrations/migrate_incident_issues_to_incident_type_spec.rb).
```ruby ```ruby
require 'spec_helper' # frozen_string_literal: true
require 'spec_helper'
require_migration! require_migration!
RSpec.describe MigratePipelineStages do RSpec.describe MigrateIncidentIssuesToIncidentType do
# Create test data - pipeline and CI/CD jobs. let(:migration) { described_class.new }
let(:jobs) { table(:ci_builds) }
let(:stages) { table(:ci_stages) }
let(:pipelines) { table(:ci_pipelines) }
let(:projects) { table(:projects) } let(:projects) { table(:projects) }
let(:namespaces) { table(:namespaces) }
let(:labels) { table(:labels) }
let(:issues) { table(:issues) }
let(:label_links) { table(:label_links) }
let(:label_props) { IncidentManagement::CreateIncidentLabelService::LABEL_PROPERTIES }
let(:namespace) { namespaces.create!(name: 'foo', path: 'foo') }
let!(:project) { projects.create!(namespace_id: namespace.id) }
let(:label) { labels.create!(project_id: project.id, **label_props) }
let!(:incident_issue) { issues.create!(project_id: project.id) }
let!(:other_issue) { issues.create!(project_id: project.id) }
# Issue issue_type enum
let(:issue_type) { 0 }
let(:incident_type) { 1 }
before do before do
projects.create!(id: 123, name: 'gitlab1', path: 'gitlab1') label_links.create!(target_id: incident_issue.id, label_id: label.id, target_type: 'Issue')
pipelines.create!(id: 1, project_id: 123, ref: 'master', sha: 'adf43c3a')
jobs.create!(id: 1, commit_id: 1, project_id: 123, stage_idx: 2, stage: 'build')
jobs.create!(id: 2, commit_id: 1, project_id: 123, stage_idx: 1, stage: 'test')
end end
# Test just the up migration. describe '#up' do
it 'correctly migrates pipeline stages' do it 'updates the incident issue type' do
expect(stages.count).to be_zero expect { migrate! }
.to change { incident_issue.reload.issue_type }
migrate! .from(issue_type)
.to(incident_type)
expect(stages.count).to eq 2 expect(other_issue.reload.issue_type).to eql(issue_type)
expect(stages.all.pluck(:name)).to match_array %w[test build] end
end end
# Test a reversible migration. describe '#down' do
it 'correctly migrates up and down pipeline stages' do let!(:incident_issue) { issues.create!(project_id: project.id, issue_type: issue_type) }
reversible_migration do |migration|
# Expectations will run before the up migration, it 'updates the incident issue type' do
# and then again after the down migration migration.up
migration.before -> {
expect(stages.count).to be_zero expect { migration.down }
} .to change { incident_issue.reload.issue_type }
.from(incident_type)
# Expectations will run after the up migration. .to(issue_type)
migration.after -> {
expect(stages.count).to eq 2 expect(other_issue.reload.issue_type).to eql(issue_type)
expect(stages.all.pluck(:name)).to match_array %w[test build]
}
end end
end
end end
``` ```
...@@ -357,41 +368,62 @@ end ...@@ -357,41 +368,62 @@ end
### Example background migration test ### Example background migration test
This spec tests the This spec tests the
[`lib/gitlab/background_migration/archive_legacy_traces.rb`](https://gitlab.com/gitlab-org/gitlab-foss/blob/v11.6.5/lib/gitlab/background_migration/archive_legacy_traces.rb) [`lib/gitlab/background_migration/backfill_draft_status_on_merge_requests.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/background_migration/backfill_draft_status_on_merge_requests.rb)
background migration. You can find the complete spec on background migration. You can find the complete spec on
[`spec/lib/gitlab/background_migration/archive_legacy_traces_spec.rb`](https://gitlab.com/gitlab-org/gitlab-foss/blob/v11.6.5/spec/lib/gitlab/background_migration/archive_legacy_traces_spec.rb) [`spec/lib/gitlab/background_migration/backfill_draft_status_on_merge_requests_spec.rb`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/spec/lib/gitlab/background_migration/backfill_draft_status_on_merge_requests_spec.rb)
```ruby ```ruby
# frozen_string_literal: true
require 'spec_helper' require 'spec_helper'
describe Gitlab::BackgroundMigration::ArchiveLegacyTraces, schema: 20180529152628 do RSpec.describe Gitlab::BackgroundMigration::BackfillDraftStatusOnMergeRequests do
include TraceHelpers let(:namespaces) { table(:namespaces) }
let(:projects) { table(:projects) }
let(:merge_requests) { table(:merge_requests) }
let(:namespaces) { table(:namespaces) } let(:group) { namespaces.create!(name: 'gitlab', path: 'gitlab') }
let(:projects) { table(:projects) } let(:project) { projects.create!(namespace_id: group.id) }
let(:builds) { table(:ci_builds) }
let(:job_artifacts) { table(:ci_job_artifacts) }
before do let(:draft_prefixes) { ["[Draft]", "(Draft)", "Draft:", "Draft", "[WIP]", "WIP:", "WIP"] }
namespaces.create!(id: 123, name: 'gitlab1', path: 'gitlab1')
projects.create!(id: 123, name: 'gitlab1', path: 'gitlab1', namespace_id: 123) def create_merge_request(params)
@build = builds.create!(id: 1, project_id: 123, status: 'success', type: 'Ci::Build') common_params = {
target_project_id: project.id,
target_branch: 'feature1',
source_branch: 'master'
}
merge_requests.create!(common_params.merge(params))
end end
context 'when trace file exists at the right place' do context "for MRs with #draft? == true titles but draft attribute false" do
let(:mr_ids) { merge_requests.all.collect(&:id) }
before do before do
create_legacy_trace(@build, 'trace in file') draft_prefixes.each do |prefix|
(1..4).each do |n|
create_merge_request(
title: "#{prefix} This is a title",
draft: false,
state_id: n
)
end
end
end end
it 'correctly archive legacy traces' do it "updates all open draft merge request's draft field to true" do
expect(job_artifacts.count).to eq(0) mr_count = merge_requests.all.count
expect(File.exist?(legacy_trace_path(@build))).to be_truthy
expect { subject.perform(mr_ids.first, mr_ids.last) }
.to change { MergeRequest.where(draft: false).count }
.from(mr_count).to(mr_count - draft_prefixes.length)
end
described_class.new.perform(1, 1) it "marks successful slices as completed" do
expect(subject).to receive(:mark_job_as_succeeded).with(mr_ids.first, mr_ids.last)
expect(job_artifacts.count).to eq(1) subject.perform(mr_ids.first, mr_ids.last)
expect(File.exist?(legacy_trace_path(@build))).to be_falsy
expect(File.read(archived_trace_path(job_artifacts.first))).to eq('trace in file')
end end
end end
end end
......
...@@ -125,8 +125,6 @@ You can also use [Kroki](https://kroki.io) to create a wide variety of diagrams. ...@@ -125,8 +125,6 @@ You can also use [Kroki](https://kroki.io) to create a wide variety of diagrams.
#### Mermaid #### Mermaid
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/15107) in GitLab 10.3.
Visit the [official page](https://mermaidjs.github.io/) for more details. The Visit the [official page](https://mermaidjs.github.io/) for more details. The
[Mermaid Live Editor](https://mermaid-js.github.io/mermaid-live-editor/) helps you [Mermaid Live Editor](https://mermaid-js.github.io/mermaid-live-editor/) helps you
learn Mermaid and debug issues in your Mermaid code. Use it to identify and resolve learn Mermaid and debug issues in your Mermaid code. Use it to identify and resolve
...@@ -211,7 +209,7 @@ Sometimes you want to :monkey: around a bit and add some :star2: to your :speech ...@@ -211,7 +209,7 @@ Sometimes you want to :monkey: around a bit and add some :star2: to your :speech
You can use it to point out a :bug: or warn about :speak_no_evil: patches. And if someone improves your really :snail: code, send them some :birthday:. People :heart: you for that. You can use it to point out a :bug: or warn about :speak_no_evil: patches. And if someone improves your really :snail: code, send them some :birthday:. People :heart: you for that.
If you're new to this, don't be :fearful:. You can join the emoji :family:. All you need to do is to look up one of the supported codes. If you're new to this, don't be :fearful:. You can join the emoji :family:. Just look up one of the supported codes.
Consult the [Emoji Cheat Sheet](https://www.emojicopy.com) for a list of all supported emoji codes. :thumbsup: Consult the [Emoji Cheat Sheet](https://www.emojicopy.com) for a list of all supported emoji codes. :thumbsup:
``` ```
...@@ -222,7 +220,7 @@ Sometimes you want to <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/ma ...@@ -222,7 +220,7 @@ Sometimes you want to <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/ma
You can use it to point out a<img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/bug.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> or warn about <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/speak_no_evil.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> patches. If someone improves your really <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/snail.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> code, send them some <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/birthday.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. People <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/heart.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> you for that. You can use it to point out a<img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/bug.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> or warn about <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/speak_no_evil.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> patches. If someone improves your really <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/snail.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> code, send them some <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/birthday.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. People <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/heart.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> you for that.
If you're new to this, don't be <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/fearful.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. You can join the emoji <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/family.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. All you need to do is to look up one of the supported codes. If you're new to this, don't be <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/fearful.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. You can join the emoji <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/family.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">. Just look up one of the supported codes.
Consult the [Emoji Cheat Sheet](https://www.webfx.com/tools/emoji-cheat-sheet/) for a list of all supported emoji codes. <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/thumbsup.png" width="20px" height="20px" style="display:inline;margin:0;border: 0"> Consult the [Emoji Cheat Sheet](https://www.webfx.com/tools/emoji-cheat-sheet/) for a list of all supported emoji codes. <img src="https://gitlab.com/gitlab-org/gitlab-foss/raw/master/public/-/emojis/2/thumbsup.png" width="20px" height="20px" style="display:inline;margin:0;border: 0">
...@@ -244,8 +242,6 @@ this font installed by default. ...@@ -244,8 +242,6 @@ this font installed by default.
### Front matter ### Front matter
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/merge_requests/23331) in GitLab 11.6.
Front matter is metadata included at the beginning of a Markdown document, preceding Front matter is metadata included at the beginning of a Markdown document, preceding
the content. This data can be used by static site generators like [Jekyll](https://jekyllrb.com/docs/front-matter/), the content. This data can be used by static site generators like [Jekyll](https://jekyllrb.com/docs/front-matter/),
[Hugo](https://gohugo.io/content-management/front-matter/), and many other applications. [Hugo](https://gohugo.io/content-management/front-matter/), and many other applications.
...@@ -356,18 +352,18 @@ in a [code block](#code-spans-and-blocks) with the language declared as `math` i ...@@ -356,18 +352,18 @@ in a [code block](#code-spans-and-blocks) with the language declared as `math` i
on a separate line: on a separate line:
````markdown ````markdown
This math is inline $`a^2+b^2=c^2`$. This math is inline: $`a^2+b^2=c^2`$.
This is on a separate line: This math is on a separate line:
```math ```math
a^2+b^2=c^2 a^2+b^2=c^2
``` ```
```` ````
This math is inline $`a^2+b^2=c^2`$. This math is inline: $`a^2+b^2=c^2`$.
This is on a separate line This math is on a separate line:
```math ```math
a^2+b^2=c^2 a^2+b^2=c^2
...@@ -408,16 +404,17 @@ To create a task list, follow the format of an ordered or unordered list: ...@@ -408,16 +404,17 @@ To create a task list, follow the format of an ordered or unordered list:
### Table of contents ### Table of contents
A table of contents is an unordered list that links to subheadings in the document. A table of contents is an unordered list that links to subheadings in the document.
To add a table of contents to a Markdown file, wiki page, issue request, or merge request
description, add either the `[[_TOC_]]` or `[TOC]` tag on its own line.
NOTE:
You can add a table of contents to issues and merge requests, but you can't add one You can add a table of contents to issues and merge requests, but you can't add one
to notes or comments. to notes or comments. Add either the `[[_TOC_]]` or `[TOC]` tag on its own line
to the **Description** field of any of the supported content types:
- Markdown files.
- Wiki pages.
- Issues.
- Merge requests.
```markdown ```markdown
This is an intro sentence to my Wiki page. This sentence introduces my wiki page.
[[_TOC_]] [[_TOC_]]
...@@ -579,7 +576,7 @@ by starting the lines of the blockquote with `>`: ...@@ -579,7 +576,7 @@ by starting the lines of the blockquote with `>`:
Quote break. Quote break.
> This is a very long line that is still quoted properly when it wraps. Keep writing to make sure this line is long enough to actually wrap for everyone. You can also *add* **Markdown** into a blockquote. > This very long line is still quoted properly when it wraps. Keep writing to make sure this line is long enough to actually wrap for everyone. You can also *add* **Markdown** into a blockquote.
``` ```
> Blockquotes help you emulate reply text. > Blockquotes help you emulate reply text.
...@@ -587,7 +584,7 @@ Quote break. ...@@ -587,7 +584,7 @@ Quote break.
Quote break. Quote break.
> This is a very long line that is still quoted properly when it wraps. Keep writing to make sure this line is long enough to actually wrap for everyone. You can also *add* **Markdown** into a blockquote. > This very long line is still quoted properly when it wraps. Keep writing to make sure this line is long enough to actually wrap for everyone. You can also *add* **Markdown** into a blockquote.
#### Multiline blockquote #### Multiline blockquote
...@@ -706,7 +703,7 @@ puts markdown.to_html ...@@ -706,7 +703,7 @@ puts markdown.to_html
``` ```
No language indicated, so no syntax highlighting. No language indicated, so no syntax highlighting.
s = "There is no highlighting for this." s = "No highlighting is shown for this line."
But let's throw in a <b>tag</b>. But let's throw in a <b>tag</b>.
``` ```
```` ````
...@@ -733,13 +730,13 @@ puts markdown.to_html ...@@ -733,13 +730,13 @@ puts markdown.to_html
```plaintext ```plaintext
No language indicated, so no syntax highlighting. No language indicated, so no syntax highlighting.
s = "There is no highlighting for this." s = "No highlighting is shown for this line."
But let's throw in a <b>tag</b>. But let's throw in a <b>tag</b>.
``` ```
### Emphasis ### Emphasis
There are multiple ways to emphasize text in Markdown. You can italicize, bold, strikethrough, In Markdown, you can emphasize text in multiple ways. You can italicize, bold, strikethrough,
and combine these emphasis styles together. and combine these emphasis styles together.
Strikethrough is not part of the core Markdown standard, but is part of GitLab Flavored Markdown. Strikethrough is not part of the core Markdown standard, but is part of GitLab Flavored Markdown.
...@@ -819,9 +816,9 @@ Do not edit the following codeblock. It uses HTML to skip the Vale ReferenceLink ...@@ -819,9 +816,9 @@ Do not edit the following codeblock. It uses HTML to skip the Vale ReferenceLink
This reference tag is a mix of letters and numbers. [^footnote-42] This reference tag is a mix of letters and numbers. [^footnote-42]
&#91;^1]: This is the text inside a footnote. &#91;^1]: This text is inside a footnote.
&#91;^footnote-42]: This is another footnote. &#91;^footnote-42]: This text is another footnote.
</code></pre> </code></pre>
A footnote reference tag looks like this:[^1] A footnote reference tag looks like this:[^1]
...@@ -833,9 +830,9 @@ Do not delete the single space before the [^1] and [^footnotes] references below ...@@ -833,9 +830,9 @@ Do not delete the single space before the [^1] and [^footnotes] references below
These are used to force the Vale ReferenceLinks check to skip these examples. These are used to force the Vale ReferenceLinks check to skip these examples.
--> -->
[^1]: This is the text inside a footnote. [^1]: This text is inside a footnote.
[^footnote-42]: This is another footnote. [^footnote-42]: This text is another footnote.
### Headers ### Headers
...@@ -893,8 +890,8 @@ Would generate the following link IDs: ...@@ -893,8 +890,8 @@ Would generate the following link IDs:
1. `this-header-has-spaces-in-it-2` 1. `this-header-has-spaces-in-it-2`
1. `this-header-has-3-5-in-it-and-parentheses` 1. `this-header-has-3-5-in-it-and-parentheses`
Note that the emoji processing happens before the header IDs are generated, so the Emoji processing happens before the header IDs are generated. The
emoji is converted to an image which is then removed from the ID. emoji is converted to an image, which is then removed from the ID.
### Horizontal Rule ### Horizontal Rule
...@@ -934,7 +931,7 @@ Reference-style (hover to see title text): ...@@ -934,7 +931,7 @@ Reference-style (hover to see title text):
</code></pre> </code></pre>
<!-- <!--
DO NOT change the name of markdown_logo.png. This is used for a test in DO NOT change the name of markdown_logo.png. This file is used for a test in
spec/controllers/help_controller_spec.rb. spec/controllers/help_controller_spec.rb.
--> -->
...@@ -951,7 +948,7 @@ Do not change to a reference style link. ...@@ -951,7 +948,7 @@ Do not change to a reference style link.
![alt text](img/markdown_logo.png "Title Text") ![alt text](img/markdown_logo.png "Title Text")
In the rare case where you need to set a specific height or width for an image, In the rare case where you must set a specific height or width for an image,
you can use the `img` HTML tag instead of Markdown and set its `height` and you can use the `img` HTML tag instead of Markdown and set its `height` and
`width` parameters. `width` parameters.
...@@ -1129,8 +1126,8 @@ These details <em>remain</em> <b>hidden</b> until expanded. ...@@ -1129,8 +1126,8 @@ These details <em>remain</em> <b>hidden</b> until expanded.
### Line breaks ### Line breaks
A line break is inserted (a new paragraph starts) if the previous text is A line break is inserted (a new paragraph starts) if the previous text is
ended with two newlines, like when you hit <kbd>Enter</kbd> twice in a row. If you only ended with two newlines, like when you press <kbd>Enter</kbd> twice in a row. If you only
use one newline (hit <kbd>Enter</kbd> once), the next sentence remains part of the use one newline (select <kbd>Enter</kbd> once), the next sentence remains part of the
same paragraph. Use this approach if you want to keep long lines from wrapping, and keep same paragraph. Use this approach if you want to keep long lines from wrapping, and keep
them editable: them editable:
...@@ -1156,7 +1153,8 @@ in the *same paragraph*. ...@@ -1156,7 +1153,8 @@ in the *same paragraph*.
#### Newlines #### Newlines
GitLab Flavored Markdown adheres to the Markdown specification in how [paragraphs and line breaks are handled](https://spec.commonmark.org/current/). GitLab Flavored Markdown adheres to the Markdown specification for handling
[paragraphs and line breaks](https://spec.commonmark.org/current/).
A paragraph is one or more consecutive lines of text, separated by one or A paragraph is one or more consecutive lines of text, separated by one or
more blank lines (two newlines at the end of the first paragraph), as [explained above](#line-breaks). more blank lines (two newlines at the end of the first paragraph), as [explained above](#line-breaks).
...@@ -1178,25 +1176,25 @@ A new line due to the previous backslash. ...@@ -1178,25 +1176,25 @@ A new line due to the previous backslash.
### Links ### Links
There are two ways to create links, inline-style and reference-style: You can create links two ways: inline-style and reference-style. For example:
<!-- <!--
Do not edit the following codeblock. It uses HTML to skip the Vale ReferenceLinks test. Do not edit the following codeblock. It uses HTML to skip the Vale ReferenceLinks test.
--> -->
<pre class="highlight"><code>- This is an [inline-style link](https://www.google.com) <pre class="highlight"><code>- This line shows an [inline-style link](https://www.google.com)
- This is a [link to a repository file in the same directory](index.md) - This line shows a [link to a repository file in the same directory](index.md)
- This is a [relative link to a readme one directory higher](../index.md) - This line shows a [relative link to a readme one directory higher](../index.md)
- This is a [link that also has title text](https://www.google.com "This link takes you to Google!") - This line shows a [link that also has title text](https://www.google.com "This link takes you to Google!")
Using header ID anchors: Using header ID anchors:
- This links to [a section on a different Markdown page, using a "#" and the header ID](index.md#overview) - This line links to [a section on a different Markdown page, using a "#" and the header ID](index.md#overview)
- This links to [a different section on the same page, using a "#" and the header ID](#header-ids-and-links) - This line links to [a different section on the same page, using a "#" and the header ID](#header-ids-and-links)
Using references: Using references:
- This is a [reference-style link, see below][Arbitrary case-insensitive reference text] - This line shows a [reference-style link, see below][Arbitrary case-insensitive reference text]
- You can [use numbers for reference-style link definitions, see below][1] - You can [use numbers for reference-style link definitions, see below][1]
- Or leave it empty and use the [link text itself][], see below. - Or leave it empty and use the [link text itself][], see below.
...@@ -1207,15 +1205,15 @@ Some text to show that the reference links can follow later. ...@@ -1207,15 +1205,15 @@ Some text to show that the reference links can follow later.
&#91;link text itself]: https://www.reddit.com &#91;link text itself]: https://www.reddit.com
</code></pre> </code></pre>
- This is an [inline-style link](https://www.google.com) - This line shows an [inline-style link](https://www.google.com)
- This is a [link to a repository file in the same directory](index.md) - This line shows a [link to a repository file in the same directory](index.md)
- This is a [relative link to a README one directory higher](../index.md) - This line shows a [relative link to a README one directory higher](../index.md)
- This is a [link that also has title text](https://www.google.com "This link takes you to Google!") - This line shows a [link that also has title text](https://www.google.com "This link takes you to Google!")
Using header ID anchors: Using header ID anchors:
- This links to [a section on a different Markdown page, using a "#" and the header ID](index.md#overview) - This line links to [a section on a different Markdown page, using a "#" and the header ID](index.md#overview)
- This links to [a different section on the same page, using a "#" and the header ID](#header-ids-and-links) - This line links to [a different section on the same page, using a "#" and the header ID](#header-ids-and-links)
Using references: Using references:
...@@ -1224,7 +1222,7 @@ The example below uses in-line links to pass the Vale ReferenceLinks test. ...@@ -1224,7 +1222,7 @@ The example below uses in-line links to pass the Vale ReferenceLinks test.
Do not change to reference style links. Do not change to reference style links.
--> -->
- This is a [reference-style link, see below](https://www.mozilla.org/en-US/) - This line is a [reference-style link, see below](https://www.mozilla.org/en-US/)
- You can [use numbers for reference-style link definitions, see below](https://slashdot.org) - You can [use numbers for reference-style link definitions, see below](https://slashdot.org)
- Or leave it empty and use the [link text itself](https://www.reddit.com), see below. - Or leave it empty and use the [link text itself](https://www.reddit.com), see below.
...@@ -1232,7 +1230,7 @@ Some text to show that the reference links can follow later. ...@@ -1232,7 +1230,7 @@ Some text to show that the reference links can follow later.
NOTE: NOTE:
Relative links do not allow the referencing of project files in a wiki Relative links do not allow the referencing of project files in a wiki
page, or a wiki page in a project file. The reason for this is that a wiki is always page, or a wiki page in a project file. The reason: a wiki is always
in a separate Git repository in GitLab. For example, `[I'm a reference-style link](style)` in a separate Git repository in GitLab. For example, `[I'm a reference-style link](style)`
points the link to `wikis/style` only when the link is inside of a wiki Markdown file. points the link to `wikis/style` only when the link is inside of a wiki Markdown file.
...@@ -1261,14 +1259,14 @@ GitLab Flavored Markdown auto-links almost any URL you put into your text: ...@@ -1261,14 +1259,14 @@ GitLab Flavored Markdown auto-links almost any URL you put into your text:
<!-- vale gitlab.Spelling = YES --> <!-- vale gitlab.Spelling = YES -->
### Lists ### Lists
Ordered and unordered lists can be created. You can create ordered and unordered lists.
For an ordered list, add the number you want the list For an ordered list, add the number you want the list
to start with, like `1.`, followed by a space, at the start of each line for ordered lists. to start with, like `1.`, followed by a space, at the start of each line for ordered lists.
After the first number, it does not matter what number you use, ordered lists are After the first number, it does not matter what number you use. Ordered lists are
numbered automatically by vertical order, so repeating `1.` for all items in the numbered automatically by vertical order, so repeating `1.` for all items in the
same list is common. If you start with a number other than `1.`, it uses that as the first same list is common. If you start with a number other than `1.`, it uses that as the first
number, and count up from there. number, and counts up from there.
Examples: Examples:
...@@ -1360,10 +1358,9 @@ Example: ...@@ -1360,10 +1358,9 @@ Example:
--- ---
If the paragraph of the first item is not indented with the proper number of spaces, If the first item's paragraph isn't indented with the proper number of spaces,
the paragraph appears outside the list, instead of properly indented under the list item. the paragraph appears outside the list, instead of properly indented under the list item.
For example:
Example:
```markdown ```markdown
1. First ordered list item 1. First ordered list item
...@@ -1455,13 +1452,13 @@ use `<br>` tags to force a cell to have multiple lines: ...@@ -1455,13 +1452,13 @@ use `<br>` tags to force a cell to have multiple lines:
```markdown ```markdown
| Name | Details | | Name | Details |
| --- | --- | | --- | --- |
| Item1 | This is on one line | | Item1 | This text is on one line |
| Item2 | This item has:<br>- Multiple items<br>- That we want listed separately | | Item2 | This item has:<br>- Multiple items<br>- That we want listed separately |
``` ```
| Name | Details | | Name | Details |
| --- | --- | | --- | --- |
| Item1 | This is on one line | | Item1 | This text is on one line |
| Item2 | This item has:<br>- Multiple items<br>- That we want listed separately | | Item2 | This item has:<br>- Multiple items<br>- That we want listed separately |
You can use HTML formatting in GitLab itself to add [task lists](#task-lists) with checkboxes, You can use HTML formatting in GitLab itself to add [task lists](#task-lists) with checkboxes,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment