Commit 2eaa98f2 authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab master

parents 85030933 4b1e65aa
...@@ -51,10 +51,6 @@ export default { ...@@ -51,10 +51,6 @@ export default {
}, },
methods: { methods: {
...mapActions(['toggleBoardItem', 'setAssignees']), ...mapActions(['toggleBoardItem', 'setAssignees']),
updateAssignees(data) {
const assignees = data.issueSetAssignees?.issue?.assignees?.nodes || [];
this.setAssignees(assignees);
},
handleClose() { handleClose() {
this.toggleBoardItem({ boardItem: this.activeIssue, sidebarType: this.sidebarType }); this.toggleBoardItem({ boardItem: this.activeIssue, sidebarType: this.sidebarType });
}, },
...@@ -78,7 +74,7 @@ export default { ...@@ -78,7 +74,7 @@ export default {
:full-path="fullPath" :full-path="fullPath"
:initial-assignees="activeIssue.assignees" :initial-assignees="activeIssue.assignees"
class="assignee" class="assignee"
@assignees-updated="updateAssignees" @assignees-updated="setAssignees"
/> />
<board-sidebar-epic-select class="epic" /> <board-sidebar-epic-select class="epic" />
<div> <div>
......
...@@ -69,6 +69,7 @@ export default { ...@@ -69,6 +69,7 @@ export default {
'milestoneTitle', 'milestoneTitle',
'releaseTag', 'releaseTag',
'search', 'search',
'myReactionEmoji',
]); ]);
filterParams.not = transformNotFilters(filters); filterParams.not = transformNotFilters(filters);
commit(types.SET_FILTERS, filterParams); commit(types.SET_FILTERS, filterParams);
......
...@@ -66,8 +66,8 @@ export default { ...@@ -66,8 +66,8 @@ export default {
}, },
listClasses() { listClasses() {
return { return {
'gl-pl-7': this.nestedLevel === 1, 'gl-pl-9': this.nestedLevel === 1,
'gl-pl-9': this.nestedLevel === 2, 'gl-pl-11-5': this.nestedLevel === 2,
}; };
}, },
}, },
......
...@@ -88,8 +88,8 @@ export default { ...@@ -88,8 +88,8 @@ export default {
}, },
listClasses() { listClasses() {
return { return {
'gl-pl-7': this.nestedLevel === 1, 'gl-pl-9': this.nestedLevel === 1,
'gl-pl-8': this.nestedLevel === 2, 'gl-pl-11-5': this.nestedLevel === 2,
}; };
}, },
}, },
......
...@@ -51,7 +51,7 @@ export default { ...@@ -51,7 +51,7 @@ export default {
if (!this.nestedSummary) { if (!this.nestedSummary) {
return ['gl-px-5']; return ['gl-px-5'];
} }
return ['gl-pl-7', 'gl-pr-5', { 'gl-bg-gray-10': this.statusIcon === ICON_WARNING }]; return ['gl-pl-9', 'gl-pr-5', { 'gl-bg-gray-10': this.statusIcon === ICON_WARNING }];
}, },
statusIconSize() { statusIconSize() {
if (!this.nestedSummary) { if (!this.nestedSummary) {
......
...@@ -24,7 +24,7 @@ export default { ...@@ -24,7 +24,7 @@ export default {
n__( n__(
'Reports|Failed %{count} time in %{base_branch} in the last 14 days', 'Reports|Failed %{count} time in %{base_branch} in the last 14 days',
'Reports|Failed %{count} times in %{base_branch} in the last 14 days', 'Reports|Failed %{count} times in %{base_branch} in the last 14 days',
this.issue.recent_failures.count, this.issue.recent_failures?.count,
), ),
this.issue.recent_failures, this.issue.recent_failures,
); );
...@@ -44,20 +44,20 @@ export default { ...@@ -44,20 +44,20 @@ export default {
<template> <template>
<div class="gl-display-flex gl-mt-2 gl-mb-2"> <div class="gl-display-flex gl-mt-2 gl-mb-2">
<issue-status-icon :status="status" :status-icon-size="24" class="gl-mr-3" /> <issue-status-icon :status="status" :status-icon-size="24" class="gl-mr-3" />
<gl-badge
v-if="showRecentFailures"
variant="warning"
class="gl-mr-2"
data-testid="test-issue-body-recent-failures"
>
{{ recentFailureMessage }}
</gl-badge>
<gl-button <gl-button
button-text-classes="gl-white-space-normal! gl-word-break-all gl-text-left" button-text-classes="gl-white-space-normal! gl-word-break-all gl-text-left"
variant="link" variant="link"
data-testid="test-issue-body-description" data-testid="test-issue-body-description"
@click="openModal({ issue })" @click="openModal({ issue })"
> >
<gl-badge
v-if="showRecentFailures"
variant="warning"
class="gl-mr-2"
data-testid="test-issue-body-recent-failures"
>
{{ recentFailureMessage }}
</gl-badge>
{{ issue.name }} {{ issue.name }}
</gl-button> </gl-button>
</div> </div>
......
...@@ -9,6 +9,7 @@ import { ...@@ -9,6 +9,7 @@ import {
GlDropdownItem, GlDropdownItem,
GlIcon, GlIcon,
} from '@gitlab/ui'; } from '@gitlab/ui';
import { isEmpty } from 'lodash';
import { __, s__ } from '~/locale'; import { __, s__ } from '~/locale';
import ModalCopyButton from '~/vue_shared/components/modal_copy_button.vue'; import ModalCopyButton from '~/vue_shared/components/modal_copy_button.vue';
import { import {
...@@ -79,7 +80,7 @@ export default { ...@@ -79,7 +80,7 @@ export default {
return Object.keys(this.selectedPlatform).length > 0; return Object.keys(this.selectedPlatform).length > 0;
}, },
instructionsEmpty() { instructionsEmpty() {
return Object.keys(this.instructions).length === 0; return isEmpty(this.instructions);
}, },
groupId() { groupId() {
return this.group?.id ?? ''; return this.group?.id ?? '';
...@@ -212,10 +213,7 @@ export default { ...@@ -212,10 +213,7 @@ export default {
<pre <pre
class="gl-bg-gray gl-flex-fill-1 gl-white-space-pre-line" class="gl-bg-gray gl-flex-fill-1 gl-white-space-pre-line"
data-testid="binary-instructions" data-testid="binary-instructions"
> >{{ instructions.installInstructions }}</pre
{{ instructions.installInstructions }}
</pre
> >
<modal-copy-button <modal-copy-button
:title="$options.i18n.copyInstructions" :title="$options.i18n.copyInstructions"
......
...@@ -19,5 +19,5 @@ ...@@ -19,5 +19,5 @@
type: 'group', type: 'group',
reset_token_url: reset_registration_token_group_settings_ci_cd_path, reset_token_url: reset_registration_token_group_settings_ci_cd_path,
project_path: '', project_path: '',
group_path: @group.path } group_path: @group.full_path }
%br %br
---
title: Fix updating GraphQL boards cards on assignees update
merge_request: 57687
author:
type: fixed
---
title: Display error message when runner installation instructions modal cannot be
loaded correctly
merge_request: 57588
author:
type: fixed
---
title: Fix test report merge request widget summary and issues alignment
merge_request: 56768
author:
type: fixed
...@@ -8,443 +8,316 @@ type: howto ...@@ -8,443 +8,316 @@ type: howto
# Install GitLab on Microsoft Azure **(FREE SELF)** # Install GitLab on Microsoft Azure **(FREE SELF)**
WARNING: For users of the Microsoft Azure business cloud, GitLab has a pre-configured offering in
This guide is deprecated and pending an update. For the time being, use the GitLab the [Azure Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/).
[image in the Azure Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/apps/gitlabinc1586447921813.gitlabee?tab=Overview). This tutorial describes installing GitLab
Enterprise Edition in a single Virtual Machine (VM).
Azure is Microsoft's business cloud and GitLab is a pre-configured offering on
the Azure Marketplace. Hopefully, you aren't surprised to hear that Microsoft
and Azure have embraced open source software like Ubuntu, Red Hat Enterprise Linux,
and of course - GitLab! This means that you can spin up a pre-configured
GitLab VM and have your very own private GitLab up and running in around 30
minutes. Let's get started.
## Getting started
First, you'll need an account on Azure. There are three ways to do this:
- If your company (or you) already has an account, then you are ready to go!
- You can also open your own Azure account for free. _At time of writing_, you get $200
of credit to spend on Azure services for 30 days. You can use this credit to try out paid Azure
services, exploring Microsoft's cloud for free. Even after the first 30 days, you never have to pay
anything unless you decide to transition to paid services with a Pay-As-You-Go Azure subscription.
This is a great way to try out Azure and cloud computing, and you can
[read more in their comprehensive FAQ](https://azure.microsoft.com/en-us/free/free-account-faq/).
- If you have an MSDN subscription, you can activate your Azure subscriber benefits. Your MSDN
subscription gives you recurring Azure credits every month, so why not put those credits to use and
try out GitLab right now?
## Working with Azure
Once you have an Azure account, you can get started. [Log in to Azure](https://portal.azure.com)
and the first thing you will see is the Dashboard:
![Azure Dashboard](img/azure-dashboard.png)
The Dashboard gives you a quick overview of Azure resources, and from here you can build VMs,
create SQL Databases, author websites, and perform lots of other cloud tasks.
## Create New VM
The [Azure Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/) is an online store for pre-configured applications and
services which have been optimized for the cloud by software vendors like GitLab,
available on the Azure Marketplace as pre-configured solutions. In this tutorial
we will install GitLab Community Edition.
To begin creating a new GitLab VM, click on the **+ New** icon, type "GitLab" into the search
box, and then click the **"GitLab Community Edition"** search result:
![Azure - New - Search for 'GitLab'](img/azure-new-search-gitlab.png)
A new "blade" window will pop-out, where you can read more about the **"GitLab Community Edition"**
offering which is freely available under the MIT Expat License:
![Azure - New - Select 'GitLab Community Edition'](img/azure-new-gitlab-ce.png)
Click **"Create"** and you will be presented with the "Create virtual machine" blade:
![Azure - Create Virtual Machine - Basics](img/azure-create-virtual-machine-basics.png)
## Basics
The first items we need to configure are the basic settings of the underlying virtual machine:
1. Enter a `Name` for the VM - e.g. **"GitLab-CE"**
1. Select a `VM disk type` - either **HDD** _(slower, lower cost)_ or **SSD** _(faster, higher cost)_
1. Enter a `User name` - e.g. `gitlab-admin`
1. Select an `Authentication type`, either **SSH public key** or **Password**:
NOTE:
If you're unsure which authentication type to use, select **Password**
1. If you chose **SSH public key** - enter your `SSH public key` into the field provided ## Prerequisite
_(read the [SSH documentation](../../ssh/README.md) to learn more about how to set up SSH
public keys)_
1. If you chose **Password** - enter the password you wish to use _(this is the password that you
will use later in this tutorial to [SSH](https://en.wikipedia.org/wiki/Secure_Shell) into the VM, so make sure it's a strong password/passphrase)_
1. Choose the appropriate `Subscription` tier for your Azure account You'll need an account on Azure. Use of the following methods to obtain an account:
1. Choose an existing `Resource Group` or create a new one - e.g. **"GitLab-CE-Azure"**
NOTE: - If you or your company already have an account with a subscription, use that account.
A "Resource group" is a way to group related resources together for easier administration. If not, you can [open your own Azure account for free](https://azure.microsoft.com/en-us/free/).
We chose "GitLab-CE-Azure", but your resource group can have the same name as your VM. Azure's free trial gives you $200 credit to explore Azure for 30 days.
[Read more in Azure's comprehensive FAQ](https://azure.microsoft.com/en-us/free/free-account-faq/).
1. Choose a `Location` - if you're unsure, select the default location - If you have an MSDN subscription, you can activate your Azure subscriber benefits. Your MSDN
subscription gives you recurring Azure credits every month, so you can use
Here are the settings we've used: those credits and try out GitLab.
![Azure - Create Virtual Machine - Basics Completed](img/azure-create-virtual-machine-basics-password.png)
Check the settings you have entered, and then click **"OK"** when you're ready to proceed.
## Size
Next, you need to choose the size of your VM - selecting features such as the number of CPU cores, ## Deploy and configure GitLab
the amount of RAM, the size of storage (and its speed), etc.
NOTE: Because GitLab is already installed in a pre-configured image, all you have to do is
In common with other cloud vendors, Azure operates a resource/usage pricing model, i.e. create a new VM:
the more resources your VM consumes the more it will cost you to run, so make your selection
carefully. You'll see that Azure provides an _estimated_ monthly cost beneath each VM Size to help
guide your selection.
The default size - the lowest cost **"DS1_V2 Standard"** VM - meets the minimum system requirements 1. [Visit the GitLab offering in the marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/apps/gitlabinc1586447921813.gitlabee?tab=Overview)
to run a small GitLab environment for testing and evaluation purposes, and so we're going to go 1. Select **Get it now** and you will be presented with the **Create this app in Azure** window.
ahead and select this one, but please choose the size which best meets your own requirements: Select **Continue**.
1. Select one of the following options from the Azure portal:
- Select **Create** to create a VM from scratch.
- Select **Start with a pre-set configuration** to get started with some
pre-configured options. You can modify these configurations at any time.
![Azure - Create Virtual Machine - Size](img/azure-create-virtual-machine-size.png) For the sake of this guide, we'll create the VM from scratch, so
select **Create**.
NOTE: NOTE:
Be aware that while your VM is active (known as "allocated"), it will incur Be aware that while your VM is active (known as "allocated"), it incurs
"compute charges" which, ultimately, you will be billed for. So, even if you're using the compute charges for which you'll be billed. Even if you're using the
free trial credits, you'll likely want to learn free trial credits, you'll want to know
[how to properly shutdown an Azure VM to save money](https://build5nines.com/properly-shutdown-azure-vm-to-save-money/). [how to properly shutdown an Azure VM to save money](https://build5nines.com/properly-shutdown-azure-vm-to-save-money/).
See the [Azure pricing calculator](https://azure.microsoft.com/en-us/pricing/calculator/)
to learn how much resources can cost.
Go ahead and click your chosen size, then click **"Select"** when you're ready to proceed to the After you create the virtual machine, use the information in the following
next step. sections to configure it.
## Settings ### Configure the Basics tab
On the next blade, you're asked to configure the Storage, Network and Extension settings. The first items you need to configure are the basic settings of the underlying virtual machine:
We've gone with the default settings as they're sufficient for test-driving GitLab, but please
choose the settings which best meet your own requirements:
![Azure - Create Virtual Machine - Settings](img/azure-create-virtual-machine-settings.png) 1. Select the subscription model and a resource group (create a new one if it
doesn't exist).
1. Enter a name for the VM, for example `GitLab`.
1. Select a region.
1. In **Availability options**, select **Availability zone** and set it to `1`.
Read more about the [availability zones](https://docs.microsoft.com/en-us/azure/virtual-machines/availability).
1. Ensure the selected image is set to **GitLab - Gen1**.
1. Select the VM size based on the [hardware requirements](../requirements.md#hardware-requirements).
Because the minimum system requirements to run a GitLab environment for up to 500 users
is covered by the `D4s_v3` size, select that option.
1. Set the authentication type to **SSH public key**.
1. Enter a user name or leave the one that is automatically created. This is
the user you'll use to connect to the VM through SSH. By default, the user
has root access.
1. Determine if you want to provide your own SSH key or let Azure create one for you.
Read the [SSH documentation](../../ssh/README.md) to learn more about how to set up SSH
public keys.
Review the settings and then click **"OK"** when you're ready to proceed to the last step. Review your entered settings, and then proceed to the Disks tab.
## Purchase ### Configure the Disks tab
The Purchase page is the last step and here you will be presented with the price per hour for your For the disks:
new VM. You'll be billed only for the VM itself (e.g. "Standard DS1 v2") because the
**"GitLab Community Edition"** marketplace solution is free to use at 0 USD/hr:
![Azure - Create Virtual Machine - Purchase](img/azure-create-virtual-machine-purchase.png) 1. For the OS disk type, select **Premium SSD**.
1. Select the default encryption.
NOTE: [Read more about the types of disks](https://docs.microsoft.com/en-us/azure/virtual-machines/managed-disks-overview) that Azure provides.
At this stage, you can review and modify the any of the settings you have made during all
previous steps, just click on any of the four steps to re-open them.
When you have read and agreed to the terms of use and are ready to proceed, click **"Purchase"**. Review your settings, and then proceed to the Networking tab.
## Deployment ### Configure the Networking tab
At this point, Azure will begin deploying your new VM. The deployment process will take a few Use this tab to define the network connectivity for your
minutes to complete, with progress displayed on the **"Deployment"** blade: virtual machine, by configuring network interface card (NIC) settings.
You can leave them at their default settings.
![Azure - Create Virtual Machine - Deployment](img/azure-create-virtual-machine-deployment.png) Azure creates a security group by default and the VM is assigned to it.
The GitLab image in the marketplace has the following ports open by default:
Once the deployment process is complete, the new VM and its associated resources will be displayed | Port | Description |
on the Azure Dashboard (you may need to refresh the page): |------|-------------|
| 80 | Enable the VM to respond to HTTP requests, allowing public access. |
| 443 | Enable our VM to respond to HTTPS requests, allowing public access. |
| 22 | Enable our VM to respond to SSH connection requests, allowing public access (with authentication) to remote terminal sessions. |
![Azure - Dashboard - All resources](img/azure-dashboard-running-resources.png) If you want to change the ports or add any rules, you can do it
after the VM is created by going to the Networking settings in the left sidebar,
while in the VM dashboard.
The new VM can also be accessed by clicking the `All resources` or `Virtual machines` icons in the ### Configure the Management tab
Azure Portal sidebar navigation menu.
## Set up a domain name Use this tab to configure monitoring and management options
for your VM. You don't need to change the default settings.
The VM will have a public IP address (static by default), but Azure allows us to assign a friendly ### Configure the Advanced tab
DNS name to the VM, so let's go ahead and do that.
From the Dashboard, click on the **"GitLab-CE"** tile to open the management blade for the new VM. Use this tab to add additional configuration, agents, scripts
The public IP address that the VM uses is shown in the 'Essentials' section: or applications through virtual machine extensions or `cloud-init`. You don't
need to change the default settings.
![Azure - VM - Management - Public IP Address](img/azure-vm-management-public-ip.png) ### Configure the Tags tab
Click on the public IP address - which should open the **"Public IP address - Configuration"** blade, Use this tab to add name/value pairs that enable you to categorize
then click on **"Configuration"** (under "Settings"). Now enter a friendly DNS name for your instance resources. You don't need to change the default settings.
in the `DNS name label` field:
![Azure - VM - Domain Name](img/azure-vm-domain-name.png) ### Review and create the VM
In the screenshot above, you'll see that we've set the `DNS name label` to `gitlab-ce-test`. The final tab presents you with all of your selected options,
This will make our VM accessible at `gitlab-ce-test.centralus.cloudapp.azure.com` where you can review and modify your choices from the
_(the full domain name of your own VM will be different, of course)_. previous steps. Azure will run validation tests in the background,
and if you provided all of the required settings, you can
create the VM.
Click **"Save"** for the changes to take effect. After you select **Create**, if you had opted for Azure to create an SSH key pair
for you, you'll be asked to download the private SSH key. Download the key, as you'll
need it to SSH into the VM.
NOTE: After you download the key, the deployment begins.
If you want to use your own domain name, you will need to add a DNS `A` record at your
domain registrar which points to the public IP address of your Azure VM. If you do this, you'll need
to make sure your VM is configured to use a _static_ public IP address (i.e. not a _dynamic_ one)
or you will have to reconfigure the DNS `A` record each time Azure reassigns your VM a new public IP
address. Read [Public IP addresses](https://docs.microsoft.com/en-us/azure/virtual-network/public-ip-addresses) to learn more.
## Let's open some ports
At this stage you should have a running and fully operational VM. However, none of the services on
your VM (e.g. GitLab) will be publicly accessible via the internet until you have opened up the
necessary ports to enable access to those services.
Ports are opened by adding _security rules_ to the **"Network security group"** (NSG) which our VM
has been assigned to. If you followed the process above, then Azure will have automatically created
an NSG named `GitLab-CE-nsg` and assigned the `GitLab-CE` VM to it.
NOTE: ### Finish deployment
If you gave your VM a different name then the NSG automatically created by Azure will
also have a different name - the name you have your VM, with `-nsg` appended to it.
You can navigate to the NSG settings via many different routes in the Azure Portal, but one of the At this point, Azure begins to deploy your new VM. The deployment process
simplest ways is to go to the Azure Dashboard, and then click on the Network Security Group listed takes a few minutes to complete. After it's complete, the new VM and its
in the **"All resources"** tile: associated resources are displayed on the Azure Dashboard.
Select **Go to resource** to visit the dashboard of the VM.
![Azure - Dashboard - All resources - Network security group](img/azure-dashboard-highlight-nsg.png) GitLab is now deployed and ready to be used. Before doing so, however,
you need to set up the domain name and configure GitLab to use it.
With the **"Network security group"** blade open, click on **"Inbound security rules"** under ### Set up a domain name
**"Settings"**:
![Azure - Network security group - Inbound security rules](img/azure-nsg-inbound-sec-rules-highlight.png) The VM has a public IP address (static by default), but Azure allows you
to assign a descriptive DNS name to the VM:
Next, click **"Add"**: 1. From the VM dashboard, select **Configure** under **DNS name**.
1. Enter a descriptive DNS name for your instance in the **DNS name label** field,
for example `gitlab-prod`. This will make the VM accessible at
`gitlab-prod.eastus.cloudapp.azure.com`.
1. Select **Save** for the changes to take effect.
![Azure - Network security group - Inbound security rules - Add](img/azure-nsg-inbound-sec-rules-add-highlight.png) Eventually, you'll want to use your own domain name. To do this, you need to add a DNS `A` record
with your domain registrar that points to the public IP address of your Azure VM.
You can use [Azure's DNS](https://docs.microsoft.com/en-us/azure/dns/dns-delegate-domain-azure-dns)
or some [other registrar](https://docs.gitlab.com/omnibus/settings/dns.html).
### Which ports to open? ### Change the GitLab external URL
Like all servers, our VM will be running many services. However, we want to open up the correct GitLab uses `external_url` in its configuration file to set up the domain name.
ports to enable public internet access to two services in particular: If you don't set this up, when you visit the Azure friendly name, you'll
instead be redirected to the public IP.
1. **HTTP** (port 80) - opening port 80 will enable our VM to respond to HTTP requests, allowing To set up the GitLab external URL:
public access to the instance of GitLab running on our VM.
1. **SSH** (port 22) - opening port 22 will enable our VM to respond to SSH connection requests,
allowing public access (with authentication) to remote terminal sessions
_(you'll see why we need [SSH](https://en.wikipedia.org/wiki/Secure_Shell) access to our VM [later on in this tutorial](#maintaining-your-gitlab-instance))_
### Open HTTP on Port 80 1. Connect to GitLab through SSH by going to **Settings > Connect** from the VM
dashboard, and follow the instructions. Remember to sign in with the username
and SSH key you specified when you [created the VM](#configure-the-basics-tab).
The Azure VM domain name will be the one you
[set up previously](#set-up-a-domain-name). If you didn't set up a domain name for
your VM, you can use the IP address in its place.
In the **"Add inbound security rule"** blade, let's open port 80 so that our VM will accept HTTP In the case of our example:
connections:
![Azure - Add inbound security rules - HTTP](img/azure-add-inbound-sec-rule-http.png) ```shell
ssh -i <private key path> gitlab-azure@gitlab-prod.eastus.cloudapp.azure.com
```
1. Enter **"HTTP"** in the `Name` field NOTE:
1. Select **HTTP** from the options in the `Service` dropdown list If you need to reset your credentials, read
1. Make sure the `Action` is set to **Allow** [how to reset SSH credentials for a user on an Azure VM](https://docs.microsoft.com/en-us/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection#reset-ssh-credentials-for-a-user).
1. Click **"OK"**
### Open SSH on Port 22 1. Open `/etc/gitlab/gitlab.rb` with your editor.
1. Find `external_url` and replace it with your own domain name. For the sake
of this example, we'll use the friendly domain name that Azure set up.
If you use `https` in the URL, Let's Encrypt will be
[automatically enabled](https://docs.gitlab.com/omnibus/settings/ssl.html#lets-encrypt-integration),
and you'll have HTTPS by default:
Repeat the above process, adding a second Inbound security rule to open port 22, enabling our VM to ```ruby
accept [SSH](https://en.wikipedia.org/wiki/Secure_Shell) connections: external_url 'https://gitlab-prod.eastus.cloudapp.azure.com'
```
![Azure - Add inbound security rules - SSH](img/azure-add-inbound-sec-rule-ssh.png) 1. Find the following settings and comment them out, so that GitLab doesn't
pick up the wrong certificates:
1. Enter **"SSH"** in the `Name` field ```ruby
1. Select **SSH** from the options in the `Service` dropdown list # nginx['redirect_http_to_https'] = true
1. Make sure the `Action` is set to **Allow** # nginx['ssl_certificate'] = "/etc/gitlab/ssl/server.crt"
1. Click **"OK"** # nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/server.key"
```
It will take a moment for Azure to add each new Inbound Security Rule (and you may need to click on 1. Reconfigure GitLab for the changes to take effect. Run the
**"Inbound security rules"** to refresh the list), but once completed, you should see the two new following command every time you make changes to `/etc/gitlab/gitlab.rb`:
rules in the list:
![Azure - Inbound security rules - List](img/azure-inbound-sec-rules-list.png) ```shell
sudo gitlab-ctl reconfigure
```
## Connecting to GitLab You can now visit GitLab with your browser at the new external URL.
Use the domain name you set up earlier (or the public IP address) to visit your new GitLab instance ### Visit GitLab for the first time
in your browser. If everything has gone according to plan you should be presented with the
following page, asking you to set a _new_ password for the administrator account automatically
created by GitLab:
![GitLab - Change Password](img/gitlab-change-password.png) Use the domain name you set up earlier to visit your new GitLab instance
in your browser. In this example, it's `https://gitlab-prod.eastus.cloudapp.azure.com`.
Enter your _new_ password into both form fields, and then click **"Change your password"**. The first thing you'll see is the sign-in page. GitLab creates an admin user by default.
The credentials are:
Once you have changed the password you will be redirected to the GitLab login page. Use `root` as - Username: `root`
the username, enter the new password you set in the previous step, and then click **"Sign in"**: - Password: the password is automatically created, and there are [two ways to
find it](https://docs.bitnami.com/azure/faq/get-started/find-credentials).
![GitLab - Login](img/gitlab-login.png) After signing in, be sure to immediately [change the password](../../user/profile/index.md#change-your-password).
### Success? ## Maintain your GitLab instance
After signing in successfully, you should see the GitLab Projects page displaying a It's important to keep your GitLab environment up-to-date. The GitLab team is constantly making
**"Welcome to GitLab!"** message: enhancements and occasionally you may need to update for security reasons. Use the information
in this section whenever you need to update GitLab.
![GitLab - Projects Page](img/gitlab-home.png) ### Check the current version
If so, you now have a working GitLab instance on your own private Azure VM. **Congratulations!** To determine the version of GitLab you're currently running,
go to the **{admin}** **Admin Area**, and you will find the version
under the **Components** table.
## Creating your first GitLab project If there's a newer available version of GitLab that contains one or more
security fixes, GitLab displays an **Update asap** notification message that
encourages you to [update](#update-gitlab).
You can skip this section if you are familiar with Git and GitLab. Otherwise, let's create our first ### Update GitLab
project. From the Welcome page, click **"New Project"**.
Let's give our project a name and a description, and then accept the default values for everything To update GitLab to the latest version:
else:
1. Enter **"demo"** into the `Project path` project name field 1. Connect to the VM through SSH.
1. Enter a `description`, e.g. **"My awesome demo project!"** 1. Update GitLab:
1. Click **"Create project"**
![GitLab - New Project](img/gitlab-new-project.png) ```shell
sudo apt update
sudo apt install gitlab-ee
```
Once the new project has been created (which should only take a moment), you'll be redirected to This command updates GitLab and its associated components to the latest versions,
homepage for the project: and can take time to complete. You'll see various update tasks being
completed in your terminal.
![GitLab - Empty Project](img/gitlab-project-home-empty.png) NOTE:
If you get an error like
`E: The repository 'https://packages.gitlab.com/gitlab/gitlab-ee/debian buster InRelease' is not signed.`,
see the [troubleshooting section](#update-the-gpg-key-for-the-gitlab-repositories).
If you scroll further down the project's home page, you'll see some basic instructions on how to 1. After the update process is complete, you'll see a message like the
set up a local clone of your new repository and push and pull from it: following:
![GitLab - Empty Project - Basic Instructions](img/gitlab-project-home-instructions.png) ```plaintext
Upgrade complete! If your GitLab server is misbehaving try running
**That's it! You now have your own private GitLab environment installed and running in the cloud!** sudo gitlab-ctl restart
## Maintaining your GitLab instance before anything else.
```
It's important to keep your GitLab environment up-to-date. The GitLab team is constantly making Refresh your GitLab instance in the browser and go to the Admin Area. You should now have an
enhancements and occasionally you may need to update for security reasons. So let's review how to up-to-date GitLab instance.
update GitLab.
### Checking our current version ## Next steps and further configuration
To check which version of GitLab we're currently running, click on the "Admin Area" link - it's the Now that you have a functional GitLab instance, follow the
the wrench icon displayed in the top-right, next to the search box. [next steps](../index.md#next-steps) to learn what more you can do with your
new installation.
In the following screenshot you can see an **"update asap"** notification message in the top-right. ## Troubleshooting
This particular message indicates that there is a newer version of GitLab available which contains
one or more security fixes:
![GitLab - update asap](img/gitlab-admin-area.png) This section describes common errors you can encounter.
Under the **"Components"** section, we can see that our VM is currently running version `8.6.5` of ### Update the GPG key for the GitLab repositories
GitLab. This is the version of GitLab which was contained in the Azure Marketplace
**"GitLab Community Edition"** offering we used to build the VM when we wrote this tutorial.
NOTE: NOTE:
The version of GitLab in your own VM instance may well be different, but the update This is a temporary fix until the GitLab image is updated with the new
process will still be the same. GPG key.
### Connect via SSH
To perform an update, we need to connect directly to our Azure VM instance and run some commands
from the terminal. Our Azure VM is actually a server running Linux (Ubuntu), so we'll need to
connect to it using SSH ([Secure Shell](https://en.wikipedia.org/wiki/Secure_Shell)).
If you're running Windows, you'll need to connect using [PuTTY](https://www.putty.org) or an equivalent Windows SSH client.
If you're running Linux or macOS, then you already have an SSH client installed.
Remember to sign in with the username and password you specified when you The pre-configured GitLab image in Azure (provided by Bitnami) uses
[created your Azure VM](#basics). a GPG key [deprecated in April 2020](https://about.gitlab.com/blog/2020/03/30/gpg-key-for-gitlab-package-repositories-metadata-changing/).
If you need to reset your VM password, read If you try to update the repositories, you'll get the following error:
[how to reset SSH credentials for a user on an Azure VM](https://docs.microsoft.com/en-us/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection).
#### SSH from the command-line <!-- vale gitlab.ReferenceLinks = NO -->
If you're running [SSH](https://en.wikipedia.org/wiki/Secure_Shell) from the command-line (terminal), then type in the following command to ```plaintext
connect to your VM, substituting `username` and `your-azure-domain-name.com` for the correct values. [ 21.023494] apt-setup[1198]: W: GPG error: https://packages.gitlab.com/gitlab/gitlab-ee/debian buster InRelease: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 3F01618A51312F3F
[ 21.024033] apt-setup[1198]: E: The repository 'https://packages.gitlab.com/gitlab/gitlab-ee/debian buster InRelease' is not signed.
Again, remember that your Azure VM domain name will be the one you
[set up previously in the tutorial](#set-up-a-domain-name). If you didn't set up a domain name for
your VM, you can use the IP address in its place in the following command:
```shell
ssh username@your-azure-domain-name.com
``` ```
Provide your password at the prompt to authenticate. <!-- vale gitlab.ReferenceLinks = YES -->
#### SSH from Windows (PuTTY) To fix this, fetch the new GPG key:
If you're using [PuTTY](https://www.putty.org) in Windows as your [SSH](https://en.wikipedia.org/wiki/Secure_Shell) client, then you might want to take a quick
read on [using PuTTY in Windows](https://mediatemple.net/community/products/dv/204404604/using-ssh-in-putty-).
### Updating GitLab
After signing in by using SSH, enter the following command to update GitLab to
the latest version:
```shell ```shell
sudo apt-get update && sudo apt-get install gitlab-ce sudo apt install gpg-agent
``` curl "https://gitlab-org.gitlab.io/omnibus-gitlab/gitlab_new_gpg.key" --output /tmp/omnibus_gitlab_gpg.key
sudo apt-key add /tmp/omnibus_gitlab_gpg.key
This command updates GitLab and its associated components to the latest versions,
so it will take a little time to complete. You'll see various update tasks being
completed in your SSH terminal window:
![GitLab updating](img/gitlab-ssh-update-in-progress.png)
After the update process is complete, you'll see a message like this:
```plaintext
Upgrade complete! If your GitLab server is misbehaving try running
sudo gitlab-ctl restart
before anything else.
``` ```
#### Check out your updated GitLab You can now [update GitLab](#update-gitlab). For more information, read about the
[packages signatures](https://docs.gitlab.com/omnibus/update/package_signatures.html).
Refresh your GitLab instance in the browser and navigate to the Admin Area. You should now have an
up-to-date GitLab instance.
When we wrote this tutorial our Azure VM GitLab instance was updated to the latest version at time
of writing (`9.4.0`). You can see that the message which was previously displaying **"update asap"**
is now showing **"up-to-date"**:
![GitLab up to date](img/gitlab-admin-area-9.4.0.png)
## Conclusion
Naturally, we believe that GitLab is a great Git repository tool. However, GitLab is a whole lot
more than that too. GitLab unifies issues, code review, CI and CD into a single UI, helping you to
move faster from idea to production, and in this tutorial we showed you how quick and easy it is to
set up and run your own instance of GitLab on Azure, Microsoft's cloud service.
Azure is a great way to experiment with GitLab, and if you decide (as we hope) that GitLab is for
you, you can continue to use Azure as your secure, scalable cloud provider or of course run GitLab
on any cloud service you choose.
## Where to next?
Check out our other [Technical Articles](../../topics/index.md) or browse the [GitLab Documentation](../../README.md) to learn more about GitLab.
### Useful links
- [GitLab Community Edition](https://about.gitlab.com/features/)
- [GitLab Enterprise Edition](https://about.gitlab.com/features/#ee)
- [Microsoft Azure](https://azure.microsoft.com/en-us/)
- [Azure - Free Account FAQ](https://azure.microsoft.com/en-us/free/free-account-faq/)
- [Azure - Marketplace](https://azuremarketplace.microsoft.com/en-us/marketplace/)
- [Azure Portal](https://portal.azure.com)
- [Azure - Pricing Calculator](https://azure.microsoft.com/en-us/pricing/calculator/)
- [Azure - Troubleshoot SSH Connections to an Azure Linux VM](https://docs.microsoft.com/en-us/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection)
- [Azure - Properly Shutdown an Azure VM](https://build5nines.com/properly-shutdown-azure-vm-to-save-money/)
- [SSH](https://en.wikipedia.org/wiki/Secure_Shell), [PuTTY](https://www.putty.org) and [Using SSH in PuTTY](https://mediatemple.net/community/products/dv/204404604/using-ssh-in-putty-)
<!-- ## Troubleshooting
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
one might have when setting this up, or when something is changed, or on upgrading, it's
important to describe those, too. Think of things that may go wrong and include them here.
This is important to minimize requests for support and to avoid doc comments with
questions that you know someone might ask.
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
If you have none to add when creating a doc, leave this section in place
but commented out to help encourage others to add to it in the future. -->
...@@ -200,7 +200,7 @@ An invoice is generated for the renewal and available for viewing or download on ...@@ -200,7 +200,7 @@ An invoice is generated for the renewal and available for viewing or download on
### Seat Link ### Seat Link
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/208832) in [GitLab Starter](https://about.gitlab.com/pricing/) 12.9. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/208832) in GitLab 12.9.
Seat Link allows GitLab Inc. to provide our GitLab self-managed customers with prorated charges for user growth throughout the year using a quarterly reconciliation process. Seat Link allows GitLab Inc. to provide our GitLab self-managed customers with prorated charges for user growth throughout the year using a quarterly reconciliation process.
...@@ -269,7 +269,7 @@ You can view the exact JSON payload in the administration panel. To view the pay ...@@ -269,7 +269,7 @@ You can view the exact JSON payload in the administration panel. To view the pay
#### Disable Seat Link #### Disable Seat Link
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/212375) in [GitLab Starter](https://about.gitlab.com/pricing/) 12.10. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/212375) in GitLab 12.10.
Seat Link is enabled by default. Seat Link is enabled by default.
......
...@@ -126,6 +126,7 @@ export default { ...@@ -126,6 +126,7 @@ export default {
'releaseTag', 'releaseTag',
'search', 'search',
'weight', 'weight',
'myReactionEmoji',
]); ]);
// Temporarily disabled until negated filters are supported for epic boards // Temporarily disabled until negated filters are supported for epic boards
......
<script>
import { GlButton, GlSprintf } from '@gitlab/ui';
import { numberToHumanSize } from '~/lib/utils/number_utils';
import { s__ } from '~/locale';
export default {
components: {
GlButton,
GlSprintf,
},
props: {
totalSize: {
type: Number,
required: true,
},
},
i18n: {
totalSize: s__('CorpusManagement|Total Size: %{totalSize}'),
newCorpus: s__('CorpusManagement|New corpus'),
},
computed: {
formattedFileSize() {
return numberToHumanSize(this.totalSize);
},
},
methods: {
newCorpus() {
this.$emit('newcorpus');
},
},
};
</script>
<template>
<div
class="gl-h-11 gl-bg-gray-10 gl-display-flex gl-justify-content-space-between gl-align-items-center"
>
<div class="gl-ml-5">
<gl-sprintf :message="$options.i18n.totalSize">
<template #totalSize>
<span class="gl-font-weight-bold">{{ formattedFileSize }}</span>
</template>
</gl-sprintf>
</div>
<gl-button class="gl-mr-5" category="primary" variant="confirm" @click="newCorpus">
{{ this.$options.i18n.newCorpus }}
</gl-button>
</div>
</template>
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Corpus Upload component renders header 1`] = `
<div
class="gl-h-11 gl-bg-gray-10 gl-display-flex gl-justify-content-space-between gl-align-items-center"
>
<div
class="gl-ml-5"
>
<gl-sprintf-stub
message="Total Size: %{totalSize}"
/>
</div>
<gl-button-stub
buttontextclasses=""
category="primary"
class="gl-mr-5"
icon=""
size="medium"
variant="confirm"
>
New corpus
</gl-button-stub>
</div>
`;
import { GlButton } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils';
import CorpusUpload from 'ee/security_configuration/corpus_management/components/corpus_upload.vue';
describe('Corpus Upload', () => {
let wrapper;
const createComponentFactory = (mountFn = shallowMount) => (options = {}) => {
const defaultProps = { totalSize: 4e8 };
wrapper = mountFn(CorpusUpload, {
propsData: defaultProps,
...options,
});
};
const createComponent = createComponentFactory();
afterEach(() => {
wrapper.destroy();
});
describe('component', () => {
it('renders header', () => {
createComponent();
expect(wrapper.findComponent(GlButton).exists()).toBe(true);
expect(wrapper.element).toMatchSnapshot();
});
it('calls the `uploadCorpus` callback on `new corpus` button click', async () => {
createComponent({ stubs: { GlButton } });
await wrapper.findComponent(GlButton).trigger('click');
expect(wrapper.emitted().newcorpus).toEqual([[]]);
});
});
});
...@@ -8645,6 +8645,12 @@ msgstr "" ...@@ -8645,6 +8645,12 @@ msgstr ""
msgid "CorpusManagement|Fuzz testing corpus management" msgid "CorpusManagement|Fuzz testing corpus management"
msgstr "" msgstr ""
msgid "CorpusManagement|New corpus"
msgstr ""
msgid "CorpusManagement|Total Size: %{totalSize}"
msgstr ""
msgid "Could not add admins as members" msgid "Could not add admins as members"
msgstr "" msgstr ""
......
...@@ -17,8 +17,6 @@ RSpec.describe 'Project issue boards sidebar assignee', :js do ...@@ -17,8 +17,6 @@ RSpec.describe 'Project issue boards sidebar assignee', :js do
let(:card) { find('.board:nth-child(2)').first('.board-card') } let(:card) { find('.board:nth-child(2)').first('.board-card') }
before do before do
stub_feature_flags(graphql_board_lists: false)
project.add_maintainer(user) project.add_maintainer(user)
sign_in(user) sign_in(user)
......
...@@ -52,7 +52,7 @@ describe('Test issue body', () => { ...@@ -52,7 +52,7 @@ describe('Test issue body', () => {
}); });
it('renders issue name', () => { it('renders issue name', () => {
expect(findDescription().text()).toBe(failedIssue.name); expect(findDescription().text()).toContain(failedIssue.name);
}); });
it('renders failed status icon', () => { it('renders failed status icon', () => {
......
import { GlAlert } from '@gitlab/ui';
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount, createLocalVue } from '@vue/test-utils';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import createMockApollo from 'helpers/mock_apollo_helper'; import createMockApollo from 'helpers/mock_apollo_helper';
...@@ -14,7 +15,10 @@ localVue.use(VueApollo); ...@@ -14,7 +15,10 @@ localVue.use(VueApollo);
describe('RunnerInstructions component', () => { describe('RunnerInstructions component', () => {
let wrapper; let wrapper;
let fakeApollo; let fakeApollo;
let runnerPlatformsHandler;
let runnerSetupInstructionsHandler;
const findAlert = () => wrapper.findComponent(GlAlert);
const findModalButton = () => wrapper.find('[data-testid="show-modal-button"]'); const findModalButton = () => wrapper.find('[data-testid="show-modal-button"]');
const findPlatformButtons = () => wrapper.findAll('[data-testid="platform-button"]'); const findPlatformButtons = () => wrapper.findAll('[data-testid="platform-button"]');
const findArchitectureDropdownItems = () => const findArchitectureDropdownItems = () =>
...@@ -22,10 +26,10 @@ describe('RunnerInstructions component', () => { ...@@ -22,10 +26,10 @@ describe('RunnerInstructions component', () => {
const findBinaryInstructionsSection = () => wrapper.find('[data-testid="binary-instructions"]'); const findBinaryInstructionsSection = () => wrapper.find('[data-testid="binary-instructions"]');
const findRunnerInstructionsSection = () => wrapper.find('[data-testid="runner-instructions"]'); const findRunnerInstructionsSection = () => wrapper.find('[data-testid="runner-instructions"]');
beforeEach(async () => { const createComponent = () => {
const requestHandlers = [ const requestHandlers = [
[getRunnerPlatforms, jest.fn().mockResolvedValue(mockGraphqlRunnerPlatforms)], [getRunnerPlatforms, runnerPlatformsHandler],
[getRunnerSetupInstructions, jest.fn().mockResolvedValue(mockGraphqlInstructions)], [getRunnerSetupInstructions, runnerSetupInstructionsHandler],
]; ];
fakeApollo = createMockApollo(requestHandlers); fakeApollo = createMockApollo(requestHandlers);
...@@ -37,6 +41,13 @@ describe('RunnerInstructions component', () => { ...@@ -37,6 +41,13 @@ describe('RunnerInstructions component', () => {
localVue, localVue,
apolloProvider: fakeApollo, apolloProvider: fakeApollo,
}); });
};
beforeEach(async () => {
runnerPlatformsHandler = jest.fn().mockResolvedValue(mockGraphqlRunnerPlatforms);
runnerSetupInstructionsHandler = jest.fn().mockResolvedValue(mockGraphqlInstructions);
createComponent();
await wrapper.vm.$nextTick(); await wrapper.vm.$nextTick();
}); });
...@@ -46,6 +57,10 @@ describe('RunnerInstructions component', () => { ...@@ -46,6 +57,10 @@ describe('RunnerInstructions component', () => {
wrapper = null; wrapper = null;
}); });
it('should not show alert', () => {
expect(findAlert().exists()).toBe(false);
});
it('should show the "Show Runner installation instructions" button', () => { it('should show the "Show Runner installation instructions" button', () => {
const button = findModalButton(); const button = findModalButton();
...@@ -110,4 +125,23 @@ describe('RunnerInstructions component', () => { ...@@ -110,4 +125,23 @@ describe('RunnerInstructions component', () => {
expect(runner.text()).toMatch(mockGraphqlInstructions.data.runnerSetup.registerInstructions); expect(runner.text()).toMatch(mockGraphqlInstructions.data.runnerSetup.registerInstructions);
}); });
describe('when instructions cannot be loaded', () => {
beforeEach(async () => {
runnerSetupInstructionsHandler.mockRejectedValue();
createComponent();
await wrapper.vm.$nextTick();
});
it('should show alert', () => {
expect(findAlert().exists()).toBe(true);
});
it('should not show instructions', () => {
expect(findBinaryInstructionsSection().exists()).toBe(false);
expect(findRunnerInstructionsSection().exists()).toBe(false);
});
});
}); });
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