GitLab Quick Actions

Quick actions are textual shortcuts for common actions on issues, epics, merge requests, and commits that are usually done by clicking buttons or dropdowns in GitLab's UI. You can enter these commands while creating a new issue or merge request, or in comments of issues, epics, merge requests, and commits. Each command should be on a separate line in order to be properly detected and executed.

From GitLab 12.1, once an action is executed, an alert appears when a quick action is successfully applied.

Quick Actions for issues, merge requests and epics

The following quick actions are applicable to descriptions, discussions and threads in:

  • Issues
  • Merge requests
  • Epics (PREMIUM)
Command Issue Merge request Epic Action
/approve Approve the merge request. (STARTER)
/assign @user Assign one user.
/assign @user1 @user2 Assign multiple users. (STARTER)
/assign me Assign yourself.
/award :emoji: Toggle emoji award.
/child_epic <epic> Add child epic to <epic>. The <epic> value should be in the format of &epic, group&epic, or a URL to an epic (introduced in GitLab 12.0). (ULTIMATE)
/clear_weight Clear weight. (STARTER)
/close Close.
/confidential Make confidential.
/copy_metadata <!merge_request> Copy labels and milestone from another merge request in the project.
/copy_metadata <#issue> Copy labels and milestone from another issue in the project.
/create_merge_request <branch name> Create a new merge request starting from the current issue.
/done Mark To-Do as done.
/due <date> Set due date. Examples of valid <date> include in 2 days, this Friday and December 31st.
/duplicate <#issue> Mark this issue as a duplicate of another issue and mark them as related. (STARTER)
/epic <epic> Add to epic <epic>. The <epic> value should be in the format of &epic, group&epic, or a URL to an epic. (PREMIUM)
/estimate <<W>w <DD>d <hh>h <mm>m> Set time estimate. For example, /estimate 1w 3d 2h 14m.
/iteration *iteration:iteration Set iteration (Introduced in GitLab 13.1) (STARTER)
/label ~label1 ~label2 Add one or more labels. Label names can also start without a tilde (~), but mixed syntax is not supported.
/lock Lock the thread.
/merge Merge changes. Depending on the project setting, this may be when the pipeline succeeds, adding to a Merge Train, etc.
/milestone %milestone Set milestone.
/move <path/to/project> Move this issue to another project.
/parent_epic <epic> Set parent epic to <epic>. The <epic> value should be in the format of &epic, group&epic, or a URL to an epic (introduced in GitLab 12.1). (ULTIMATE)
/promote Promote issue to epic. (PREMIUM)
/publish Publish issue to an associated Status Page (Introduced in GitLab 13.0) (ULTIMATE)
/reassign @user1 @user2 Change assignee. (STARTER)
/relabel ~label1 ~label2 Replace existing labels with those specified.
/relate #issue1 #issue2 Mark issues as related. (STARTER)
/remove_child_epic <epic> Remove child epic from <epic>. The <epic> value should be in the format of &epic, group&epic, or a URL to an epic (introduced in GitLab 12.0). (ULTIMATE)
/remove_due_date Remove due date.
/remove_epic Remove from epic. (PREMIUM)
/remove_estimate Remove time estimate.
/remove_iteration Remove iteration (Introduced in GitLab 13.1) (STARTER)
/remove_milestone Remove milestone.
/remove_parent_epic Remove parent epic from epic (introduced in GitLab 12.1). (ULTIMATE)
/remove_time_spent Remove time spent.
/remove_zoom Remove Zoom meeting from this issue (introduced in GitLab 12.4).
/reopen Reopen.
/shrug <comment> Append the comment with ¯\_(ツ)_/¯.
/spend <time(-<h>h <mm>m)> <date(<YYYY-MM-DD>)> Subtract spent time. Optionally, specify the date that time was spent on. For example, /spend time(-1h 30m) or /spend time(-1h 30m) date(2018-08-26).
/spend <time(<h>h <mm>m)> <date(<YYYY-MM-DD>)> Add spent time. Optionally, specify the date that time was spent on. For example, /spend time(1h 30m) or /spend time(1h 30m) date(2018-08-26).
/submit_review Submit a pending review (introduced in GitLab 12.7). (PREMIUM)
/subscribe Subscribe to notifications.
/tableflip <comment> Append the comment with (╯°□°)╯︵ ┻━┻.
/target_branch <local branch name> Set target branch.
/title <new title> Change title.
/todo Add a To-Do.
/unassign @user1 @user2 Remove specific assignees. (STARTER)
/unassign Remove all assignees.
/unlabel ~label1 ~label2 or /remove_label ~label1 ~label2 Remove all or specific labels.
/unlock Unlock the thread.
/unsubscribe Unsubscribe from notifications.
/weight <value> Set weight. Valid options for <value> include 0, 1, 2, and so on. (STARTER)
/wip Toggle the Work In Progress status.
/zoom <Zoom URL> Add Zoom meeting to this issue (introduced in GitLab 12.4).

Autocomplete characters

Many quick actions require a parameter, for example: username, milestone, and label. Autocomplete characters can make it easier to enter a parameter, compared to selecting items from a list.

Quick actions parameters

The easiest way to set parameters for quick actions is to use autocomplete. If you manually enter a parameter, it must be enclosed in double quotation marks ("), unless it contains only these characters:

  1. ASCII letters.
  2. Numerals (0-9).
  3. Underscore (_), hyphen (-), question mark (?), dot (.), or ampersand (&).

Parameters are also case-sensitive. Autocomplete handles this, and the insertion of quotation marks, automatically.

Quick actions for commit messages

The following quick actions are applicable for commit messages:

Command Action
/tag v1.2.3 <message> Tags this commit with an optional message