GitLab Direction

This page describes the direction and roadmap for GitLab. It's organized from the short to the long term.

Your contributions

GitLab's direction is determined by GitLab the company, and the code that is sent by our contributors. We continually merge code to be released in the next version. Contributing is the best way to get a feature you want included.

On our issue tracker for CE and EE, many requests are made for features and changes to GitLab. Issues with the Accepting Merge Requests label are pre-approved as something we're willing to add to GitLab. Of course, before any code is merged it still has to meet our contribution acceptance criteria.

What our customers want

As a company, GitLab tries to make things that are useful for our customers as well as ourselves. After all, GitLab is one of the biggest users of GitLab. If a customer requests a feature, it carries extra weight. Due to our short release cycle, we can ship simple feature requests, such as an API extension, within one or two months.

Previous releases

On our release list page you can find an overview of the most important features of recent releases and links to the blog posts for each release.

Future releases

GitLab releases a new version every single month on the 22nd. Note that we often move things around, do things that are not listed, and cancel things that are listed.

This page is always in draft, meaning some of the things here might not ever be in GitLab. New premium features are indicated with "New premium feature" in the issue title. This is our best estimate of what will be new premium features, but is in no way definitive.

The list is an outline of tentpole features – the most important features of upcoming releases – and doesn't include any contributions from volunteers outside the company. This is not an authoritative list of upcoming releases - it only reflects current milestones.

GitLab Community Edition

8.17

GitLab Enterprise Edition

8.17

Future Premium Features

Below is the list of premium features we are working on. These features will be available for GitLab Enterprise Edition Premium. The higher the item on the list, the sooner we expect to ship it.

Wishlist

Below are features we'd really like to see in GitLab. This list is not prioritized. We invite everyone to join the discussion by clicking the wishlist item that is of interest to you. Feel free to comment, vote up or down any issue or just follow the conversation. For GitLab sales, please add a link to the account in Salesforce.com that has expressed interest in a wishlist feature. We very much welcome contributions that implement any of these things.

CI

Code Review

Code review meta issue

Container Registry

No current issues

Issue Boards

Issue Boards meta issue

Issue tracker

Moderation Tools

Moderation tools meta issue

Monitoring

No current issues

Open Source Projects

Features for open source projects

Pages

Performance

Usability

User management

User management meta issue

Version Control for Everything

Wiki

Wiki improvements meta issue

Moonshots

New Premium Features

No current issues

Scope

Our vision is an integrated set of tools for the software development lifecycle based on convention over configuration. To achieve this we ship the following features in our Omnibus package:

  1. Idea (Chat) => Mattermost
  2. Issue (Tracker) => Issue Tracker
  3. Plan (Board) => Issue Boards
  4. Code (IDE) => Web editor and web terminal
  5. Commit (Repo) => GitLab Repositories
  6. Test (CI) => GitLab Continuous Integration and Container Registry ship with GitLab, in the future we would love to add support for CodeClimate and have an extended vision for CI and CD.
  7. Review (MR) => GitLab Merge Requests and Review Apps
  8. Staging (CD) => GitLab Deploy and auto deploy
  9. Production (Chatops) => Mattermost slash commands and Slack slash commands
  10. Feedback (Monitoring) => Cycle Analytics ships with GitLab, in the future we plan to ship application monitoring by bundling Prometheus.

Also see our video In 13 minutes from Kubernetes to a complete application development tool.

Outside our scope

  1. Operating System Ubuntu, CentOS, RHEL, CoreOS, Alpine Linux
  2. Container Scheduler although we do want to use GitLab Deploy to deploy to CloudFoundry, OpenStack, OpenShift, Kubernetes, Mesos DCOS, Docker Swarm, Atlas/Terraform, Nomad, Deis, Convox, Flynn, Tutum, GiantSwarm, Rancher
  3. Configuration management although we do want to upload cookbooks, manifests, playbooks, and modules for respectively Chef, Puppet, Ansible, and Salt.
  4. Container configuration agents ContainerPilot, Orchestrator-agent
  5. Distributed configuration stores Consul, Etcd, Zookeeper, Vault
  6. Logging Fluentd, ELK stack, Graylog, Splunk, LogDNA
  7. Error monitoring Sentry, Airbrake, Bugsnag
  8. Network Flannel, Openflow, VMware NSX, Cisco ACI
  9. Tracing OpenTracing, LightStep
  10. Network security Nmap, rkhunter, Metasploit, Snort, OpenVAS, OSSEC

Vision

See below for a TL;DR on how and what we're building at GitLab. See this page for an in-depth in our product strategy.


From development teams to marketing organizations, everyone needs to collaborate on digital content. Content should be open to suggestions by a wide number of potential contributors. Open contribution can be achieved by using a mergeable file format and distributed version control. The vision of GitLab is to allow everyone to collaborate on all digital content so people can cooperate effectively and achieve better results, faster.

Ideas flow though many stages before they are realized. An idea originates in a chat discussion, an issue is created, it is planned in a sprint, coded in an IDE, committed to version control, tested by CI, code reviewed, deployed, checked and documented. Stitching all these stages of the software developement lifecycle together can be done in many different ways. You can have a marketplace of proprietary apps from different suppliers or use a suite of products developed in isolation. We believe that an integrated set of tools for the software development lifecycle based on convention over configuration offers a superior user experience. The advantage can be quoted from the Wikipedia page for convention over configuration: "decrease the number of decisions that developers need to make, gaining simplicity, and not necessarily losing flexibility". In GitLab you only have to specify unconventional aspects of your workflow. The happy path is frictionless from idea to production.

We admire other convention over configuration tools like Ruby on Rails (that doctrine of which perfectly describe the value of integrated systems), Ember, and Heroku, and strive to offer the same advantages for a continuous delivery of software.

We prefer to offer an integrated set of tools instead of a network of services or offering plugins for the following reasons:

  1. We think an integrated set of tools provides a better user experience than a modular approach, as detailed by this article from Stratechery.
  2. The open source nature of GitLab ensures that that we can combine great open source products.
  3. Everyone can contribute to create a feature set that is more complete than other tools. We'll focus on making all the parts work well together to create a better user experience.
  4. Because GitLab is open source the enhancements can become part of the codebase instead of being external. This ensures the automated tests for all functionality are continually run, ensuring that additions keep working work. This is contrast to externally maintained plugins that might not be updated.
  5. Having the enhancements as part of the codebase also ensures GitLab can continue to evolve with its additions instead of being bound to an API that is hard to change and that resists refactoring. Refactoring is essential to maintaining a codebase that is easy to contribute to.
  6. Many people use GitLab on-premises, for such situations it is much easier to install one tool than installing and integrating many tools.
  7. GitLab is used by many large organizations with complex purchasing processes, having to buy only one subscription simplifies their purchasing.