index.md 12.2 KB
Newer Older
1 2
# Web IDE

M
Marcia Ramos 已提交
3
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/issues/4539) in [GitLab Ultimate][ee] 10.4.
S
Stan Hu 已提交
4
> [Brought to GitLab Core](https://gitlab.com/gitlab-org/gitlab-ce/issues/44157) in 10.7.
5

M
Marcel Amirault 已提交
6 7
The Web IDE editor makes it faster and easier to contribute changes to your
projects by providing an advanced editor with commit staging.
8 9 10

## Open the Web IDE

P
Philipp C. H 已提交
11
You can open the Web IDE when viewing a file, from the repository file list,
12
and from merge requests.
13 14 15

![Open Web IDE](img/open_web_ide.png)

16
## File finder
17

M
Marcia Ramos 已提交
18
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/18323) in [GitLab Core][ce] 10.8.
19 20 21 22 23 24

The file finder allows you to quickly open files in the current branch by
searching. The file finder is launched using the keyboard shortcut `Command-p`,
`Control-p`, or `t` (when editor is not in focus). Type the filename or
file path fragments to start seeing results.

M
Marcel Amirault 已提交
25
## Syntax highlighting
26

27
As expected from an IDE, syntax highlighting for many languages within
28 29 30 31
the Web IDE will make your direct editing even easier.

The Web IDE currently provides:

32 33 34 35 36 37
- Basic syntax colorization for a variety of programming, scripting and markup
  languages such as XML, PHP, C#, C++, Markdown, Java, VB, Batch, Python, Ruby
  and Objective-C.
- IntelliSense and validation support (displaying errors and warnings, providing
  smart completions, formatting, and outlining) for some languages. For example:
TypeScript, JavaScript, CSS, LESS, SCSS, JSON and HTML.
38

39 40 41
Because the Web IDE is based on the [Monaco Editor](https://microsoft.github.io/monaco-editor/),
you can find a more complete list of supported languages in the
[Monaco languages](https://github.com/Microsoft/monaco-languages) repository.
42 43 44 45

NOTE: **Note:**
Single file editing is based on the [Ace Editor](https://ace.c9.io).

46 47
## Stage and commit changes

P
Philipp C. H 已提交
48
After making your changes, click the **Commit** button in the bottom left to
49
review the list of changed files. Click on each file to review the changes and
M
Marcel Amirault 已提交
50
click the tick icon to stage the file.
51 52

Once you have staged some changes, you can add a commit message and commit the
N
nyonyoron 已提交
53
staged changes. Unstaged changes will not be committed.
54 55 56

![Commit changes](img/commit_changes.png)

57
## Reviewing changes
58 59 60 61 62 63 64 65

Before you commit your changes, you can compare them with the previous commit
by switching to the review mode or selecting the file from the staged files
list.

An additional review mode is available when you open a merge request, which
shows you a preview of the merge request diff if you commit your changes.

66 67
## View CI job logs

M
Marcia Ramos 已提交
68
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/19279) in [GitLab Core][ce] 11.0.
69

70 71
You can use the Web IDE to quickly fix failing tests by opening
the branch or merge request in the Web IDE and opening the logs of the failed
P
Philipp C. H 已提交
72 73 74
job. You can access the status of all jobs for the most recent pipeline and job
traces for the current commit by clicking the **Pipelines** button in the top
right.
75 76 77 78 79 80

The pipeline status is also shown at all times in the status bar in the bottom
left.

## Switching merge requests

M
Marcia Ramos 已提交
81
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/19318) in [GitLab Core][ce] 11.0.
82

83 84
To switch between your authored and assigned merge requests, click the
dropdown in the top of the sidebar to open a list of merge requests. You will
P
Philipp C. H 已提交
85 86
need to commit or discard all your changes before switching to a different merge
request.
87

88 89
## Switching branches

M
Marcia Ramos 已提交
90
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/20850) in [GitLab Core][ce] 11.2.
91

92 93 94
To switch between branches of the current project repository, click the dropdown
in the top of the sidebar to open a list of branches.
You will need to commit or discard all your changes before switching to a
P
Philipp C. H 已提交
95
different branch.
96

J
James Ramsay 已提交
97
## Client Side Evaluation
98

M
Marcia Ramos 已提交
99
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/19764) in [GitLab Core][ce] 11.2.
100

P
Philipp C. H 已提交
101
You can use the Web IDE to preview JavaScript projects right in the browser.
J
James Ramsay 已提交
102
This feature uses CodeSandbox to compile and bundle the JavaScript used to
103
preview the web application.
104

J
James Ramsay 已提交
105
![Web IDE Client Side Evaluation](img/clientside_evaluation.png)
106

P
Philipp C. H 已提交
107
Additionally, for public projects an **Open in CodeSandbox** button is available
108 109 110
to transfer the contents of the project into a public CodeSandbox project to
quickly share your project with others.

J
James Ramsay 已提交
111
### Enabling Client Side Evaluation
112

J
James Ramsay 已提交
113 114 115
The Client Side Evaluation feature needs to be enabled in the GitLab instances
admin settings. Client Side Evaluation is enabled for all projects on
GitLab.com
116

J
James Ramsay 已提交
117
![Admin Client Side Evaluation setting](img/admin_clientside_evaluation.png)
118

P
Philipp C. H 已提交
119
Once you have done that, you can preview projects with a `package.json` file and
120
a `main` entry point inside the Web IDE. An example `package.json` is shown
P
Philipp C. H 已提交
121
below.
122 123 124 125 126 127 128 129 130 131

```json
{
  "main": "index.js",
  "dependencies": {
    "vue": "latest"
  }
}
```

132 133 134 135 136 137
## Interactive Web Terminals for the Web IDE **[ULTIMATE ONLY]**

> [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/issues/5426) in [GitLab Ultimate](https://about.gitlab.com/pricing/) 11.6.

CAUTION: **Warning:**
Interactive Web Terminals for the Web IDE is currently in **Beta**.
138 139
Shared Runners [do not yet support Interactive Web Terminals](https://gitlab.com/gitlab-org/gitlab-ce/issues/52611),
so you would need to use your own private Runner(s) to make use of this feature.
140

141 142 143
[Interactive Web Terminals](../../../ci/interactive_web_terminal/index.md)
give the project [Maintainers](../../permissions.md#project-members-permissions)
user access to a terminal to interact with the Runner directly from
144 145 146 147 148 149 150
GitLab, including through the Web IDE.

### Runner configuration

Some things need to be configured in the runner for the interactive web terminal
to work:

151
- The Runner needs to have
152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202
  [`[session_server]` configured properly](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-session_server-section).
- If you are using a reverse proxy with your GitLab instance, web terminals need to be
  [enabled](../../../administration/integration/terminal.md#enabling-and-disabling-terminal-support). **[ULTIMATE ONLY]**

If you have the terminal open and the job has finished with its tasks, the
terminal will block the job from finishing for the duration configured in
[`[session_server].terminal_max_retention_time`](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-session_server-section)
until you close the terminal window.

NOTE: **Note:** Not all executors are
[supported](https://docs.gitlab.com/runner/executors/#compatibility-chart)

### Web IDE configuration file

In order to enable the Web IDE terminals you need to create the file
`.gitlab/.gitlab-webide.yml` inside the repository's root. This
file is fairly similar to the [CI configuration file](../../../ci/yaml/README.md)
syntax but with some restrictions:

- No global blocks can be defined (ie: `before_script` or `after_script`)
- Only one job named `terminal` can be added to this file.
- Only the keywords `image`, `services`, `tags`, `before_script`, `script`, and
`variables` are allowed to be used to configure the job.
- To connect to the interactive terminal, the `terminal` job must be still alive
and running, otherwise the terminal won't be able to connect to the job's session.
By default the `script` keyword has the value `sleep 60` to prevent
the job from ending and giving the Web IDE enough time to connect. This means
that, if you override the default `script` value, you'll have to add a command
which would keep the job running, like `sleep`.

In the code below there is an example of this configuration file:

```yaml
terminal:
  before_script:
    - apt-get update
  script: sleep 60
  variables:
    RAILS_ENV: "test"
    NODE_ENV: "test"
```

Once the terminal has started, the console will be displayed and we could access
the project repository files.

**Important**. The terminal job is branch dependant. This means that the
configuration file used to trigger and configure the terminal will be the one in
the selected branch of the Web IDE.

If there is no configuration file in a branch, an error message will be shown.

203
### Running interactive terminals in the Web IDE
204 205 206 207 208 209 210

If Interactive Terminals are available for the current user, the **Terminal** button
will be visible in the right sidebar of the Web IDE. Click this button to open
or close the terminal tab.

Once open, the tab will show the **Start Web Terminal** button. This button may
be disabled if the environment is not configured correctly. If so, a status
211
message will describe the issue. Here are some reasons why **Start Web Terminal**
212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229
may be disabled:

- `.gitlab/.gitlab-webide.yml` does not exist or is set up incorrectly.
- No active private runners are available for the project.

If active, clicking the **Start Web Terminal** button will load the terminal view
and start connecting to the runner's terminal. At any time, the **Terminal** tab
can be closed and reopened and the state of the terminal will not be affected.

When the terminal is started and is successfully connected to the runner, then the
runner's shell prompt will appear in the terminal. From here, you can enter
commands that will be executed within the runner's environment. This is similar
to running commands in a local terminal or through SSH.

While the terminal is running, it can be stopped by clicking **Stop Terminal**.
This will disconnect the terminal and stop the runner's terminal job. From here,
click **Restart Terminal** to start a new terminal session.

230
### File syncing to web terminal
P
Paul Slaughter 已提交
231 232 233

> [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/issues/5276) in [GitLab Ultimate](https://about.gitlab.com/pricing/) 12.0.

234
File changes in the Web IDE can be synced to a running web terminal.
P
Paul Slaughter 已提交
235 236 237 238 239 240
This enables users to test their code changes in a preconfigured terminal
environment.

NOTE: **Note:**
Only file changes in the Web IDE are synced to the terminal.
Changes made in the terminal are **not** synced to the Web IDE.
241
This feature is only available for Kubernetes Runners.
P
Paul Slaughter 已提交
242

243 244
To enable file syncing to the web terminal, the `.gitlab/.gitlab-webide.yml`
file needs to have a `webide-file-sync` service configured. Here is an example
P
Paul Slaughter 已提交
245 246 247 248 249
configuration for a Node JS project which uses this service:

```yaml
terminal:
  # This can be any image that has the necessary runtime environment for your project.
250
  image:
P
Paul Slaughter 已提交
251 252 253 254 255 256 257 258 259 260 261
    name: node:10-alpine
  services:
    - name: registry.gitlab.com/gitlab-org/webide-file-sync:latest
      alias: webide-file-sync
      entrypoint: ["/bin/sh"]
      command: ["-c", "sleep 5 && ./webide-file-sync -project-dir $CI_PROJECT_DIR"]
      ports:
        # The `webide-file-sync` executable defaults to port 3000.
        - number: 3000
```

262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281
- The `webide-file-sync` executable must start **after** the project
  directory is available. This is why we need to add `sleep 5` to the `command`.
  See [this issue](https://gitlab.com/gitlab-org/webide-file-sync/issues/7) for
  more info.
- `$CI_PROJECT_DIR` is a
  [predefined environment variable](../../../ci/variables/predefined_variables.md)
  for GitLab Runners. This is where your project's repository will be.

Once you have configured the web terminal for file syncing, then when the web
terminal is started, a **Terminal** status will be visible in the status bar.

![Web IDE Client Side Evaluation](img/terminal_status.png)

Changes made to your files via the Web IDE will sync to the running terminal
when:

- <kbd>Ctrl</kbd> + <kbd>S</kbd> (or <kbd>Cmd</kbd> + <kbd>S</kbd> on Mac)
  is pressed while editing a file.
- Anything outside the file editor is clicked after editing a file.
- A file or folder is created, deleted, or renamed.
P
Paul Slaughter 已提交
282

283 284
### Limitations

285
Interactive Terminals is in a beta phase and will continue to be improved upon in upcoming
286 287 288 289 290 291 292 293 294 295 296 297 298
releases. In the meantime, please note that the user is limited to having only one
active terminal at a time.

### Troubleshooting

- If the terminal's text is gray and unresponsive, then the terminal has stopped
  and it can no longer be used. A stopped terminal can be restarted by clicking
  **Restart Terminal**.
- If the terminal displays **Connection Failure**, then the terminal could not
  connect to the runner. Please try to stop and restart the terminal. If the
  problem persists, double check your runner configuration.


299
[ce]: https://about.gitlab.com/pricing/
M
Marcia Ramos 已提交
300
[ee]: https://about.gitlab.com/pricing/