Handling trials, extensions and plan changes on GitLab.com
Handling GitLab.com trial requests
GitLab.com customers without a subscription
- New customers without an existing GitLab.com subscription and namespace can apply for a 30-day GitLab Ultimate subscription by completing the following form.
- GitLab.com users who have an existing namespace but do not have an active GitLab.com subscription can go to the billing section for their group namespace and press theĀ
Start Trial
button. If a trial previously existed on that namespace, the button will not be present. In such situations the user will need to contact GitLab Sales to request a new trial or a trial extension.
GitLab.com customers with a Premium Subscription
GitLab.com Premium customers who want to trial SaaS Ultimate have two options to do so:
- Request an Ultimate trial from GitLab’s public trial page. This will require the customer to set up a new namespace to which to apply the trial. No Sales or Support action will be required.
- Temporarily upgrade their existing GitLab Premium subscription to a GitLab Ultimate Trial.
-
As part of the initiative to enable current SaaS Premium customers to trial SaaS Ultimate on their primary namespace, the first iteration implementation now grants L&R Support the capability to temporarily upgrade an existing Premium subscription to an Ultimate trial subscription. To facilitate this process, the customer’s Account Executive must use the following instructions:
- Go to the Support Super Form; you must have a Zendesk Light Agent account to use this form.
- Under
What is this request concerning
, selectLicense and Renewal Related Requests
>GitLab Support Internal Request for Global Customers
. - In the form that appears, under
What type of GitLab Support Internal Request is this for?
, selectSaaS Trial Related
>Request an Ultimate trial for a customer using a Premium subscription
. - Fill out the required fields and click Submit request. If you need assistance filling out the form, please ask in the
#support_operations
Slack channel.
Once the form has been submitted, the L&R Support Engineer should follow the workflow outlined in the following video, which entails:
- Locating the correct
Customer
record by searchingCustomers
. - Clicking the (i) info button on the customer record.
- Going to the
Zuora Subscriptions
tab. - Selecting the appropriate namespace and pressing the
Apply Ultimate Trial
button.
Subscription seats during trials-over-subscription
When applying an Ultimate trial over a subscription, the customer’s licensed subscription seat count still applies. If the customer wishes to increase their seat count during the Ultimate trial, they will have to purchase the seats as usual. If the customer exceeds their seat allowance during the trial, they will be billed for them at their next reconciliation and the seats will still apply after the end of the trial.
Namespaces with a prior Ultimate trial
These namespaces are allowed to start an Ultimate trial over Premium subscription, circumventing the normal guardrails preventing a group from taking out more than one trial.
Workflow caveats
- For all trials, the renewal start date must align with the end date of the prior subscription term therefore requests for Ultimate trials with the purpose of extending ahead of the renewal date should be denied. It is GitLab policy to align renewal dates with the end of the prior subscription term.
- GitLab.com Ultimate trials cannot be extended past the 30-day duration.
- GitLab.com trials are only available for the GitLab Ultimate Subscription plan.
Requests to workaround GitLab.com trial limitations
GitLab.com trials have some limitations, including the use of group access tokens. Some customers may request circumvention of these limitations in cases such as facilitating post-migration checks.
Sales will need to work with Deal Desk using this workflow to request a temporary Premium or Ultimate subscription which will result in a $0 paid subscription without the trial limitations.
Support should not use the NFR workflow to process such request.
Extending trials
Sales will often request through a Zendesk Ticket that we extend the duration of GitLab.com trials on behalf of their prospects. These tickets will always be raised from the GitLab Support End User gitlab_support@example.com, with the submitter cc’d on the ticket. If a customer or sales representative raise an extend trial request on a customer ticket, we should respond that an internal request must be created by the sales representative to request the trial extension.
If any fields when opening the ticket were filled out incorrectly, send a public reply in the ticket asking the submitter to supply the missing information.
NOTE: Due to customers #973 and customers #1643, these must be done via mechanizer or CustomersDot console. Once those issues are resolved, these requests should be done via CustomersDot admin.
- Take ownership of the ZD ticket.
- Check over the request and ensure that we’ve been provided enough information to action the request. To do this check that:
- The
Namespace:
field contains a valid GitLab namespace and it that holds the active trial. This should not be a Salesforce link or email address. - The
Extend the date to:
field contains a future date. (Trial expires around 23:59 UTC on this date) - The
Trial license plan:
field is filled out
- The
- Use the Manage GitLab Plan and Trials to process the request.
- This should create a new internal request issue documenting the change action. Reference this new issue to the ZD Ticket where the extension was requested.
- If there is an error while taking action, check the internal issue to see what went wrong. Please also locate the error in sentry (see Searching Sentry if needed) and file an issue, or comment on an existing one.
- If namespace needs to be adjusted manually, then raise a new internal issue with details and
~Console Escalation::Customers
label.
If a customer is requesting a trial extension, please follow Working with Sales workflow to let Sales team know in case they would like to have a discussion with the customer.
Customer requests for a subscription extension
When a customer requests a subscription extension, follow the steps below based on the day of the week and whether the customer is classified as Enterprise or SMB.
-
Locate the Account Owner:
- In the Zendesk (ZD) ticket, look for the internal note labeled
Organization Info
to dentify the Account Owner:- For Enterprise/Commercial customers, a specific individual will be listed.
- For SMB customers, you will see
EMEA/AMER/APAC SMB Sales
instead of a named person.
- In the Zendesk (ZD) ticket, look for the internal note labeled
-
Determine next steps Based on the Day and Customer Type:
Day Enterprise/Commercial SMB Weekday Redirect to Sales Redirect to Sales Weekend/Holiday Redirect to Sales Issue temp extension and redirect to Sales -
Steps for Redirecting to Sales:
Enterprise/Commercial Customers: - Inform the customer that such requests have to be channeled through sales and provide them with their AE’s email address before closing the ticket. - Notify the Account Executive (AE) through Chatter to ensure they are aware of the request. SMB Customers: - Follow the process outlined in the Working with the Global Digital SMB Account Team handbook page. - Provide the Salesforce (SFDC) ticket ID to the customer. - Close the ticket.
-
For SMB Customers on Weekends or Holidays, please issue a temporary subscription extension before redirecting to Sales.
SFDC generated temporary renewal extensions
Account Executives (AEs) can use SalesForce.com (SFDC) to issue a SaaS 21-day Subscription extension to a customer when the renewal opportunity is taking longer than expected to close. When an AE uses this functionality, the subscription is automatically extended without any L&R Support involvement. The Temporary renewal extensions handbook entry documents this approach.
Please note that the above approach has the following caveats:
- There are guardrails in place to prevent abuse of this functionality. As a result, only one subscription extension can be generated per renewal event. Therefore, there may be occasions when L&R Support will still be required to generate further subscription extensions. If this occurs then please follow the manual process for extending an active or expired subscription.
- Additionally, the subscription has to be a non-trial subscription. If the subscription is set to expire within the next 15 days, please redirect the salesperson to utilize the SFDC feature by employing the
Deviation from SM License Extension Workflow macro
and subsequently close the ticket. - If the subscription expiration is more than 15 days away, advise the salesperson to wait until the expiry is within 15 days before utilizing the SFDC feature. Once within the 15-day window, redirect the salesperson to use the SFDC feature using the
Deviation from SM License Extension Workflow
macro and then close the ticket.
Extend an existing active or expired subscription
- Before taking any action to create the trial license, get confirmation from
the customer that they understand and accept the
constraints
that accompany a trial. Use the
Support::L&R::Trial Subscription - Exclusions Sign Off
macro in Zendesk for this purpose. Be sure to assign the ticket to yourself so that you will receive the customer’s response and be able to take action quickly. - This is done via the Mechanizer tool through Manage GitLab Plan and Trials.
Note: We cannot extend the trial if the customer hasn’t started one on the namespace. The Subscription name field in the ZenDesk Mechanizer app is there for that reason. When there’s a Subscription name, the mechanizer will create a new trial for the namespace.
Workflow diagram
graph TD; A[Issue Created]-->B[Assign Yourself]; B-->C[Issue Actionable?]; C-->J[No]; J-->K[Apply Status::Blocked and Inform Submitter]; C-->D[Yes]; D-->E[Adjust Namespace via Customers Portal]; E-->F[Did it Work?]; F-->G[Yes]; G-->H[Note Issue and Close]; F-->I[No]; I-->L[Locate Error in Sentry or comment on existing issue]; click L "/handbook/support/workflows/500_errors/#searching-sentry" "Diagnose Errors on GitLab.com" L-->M[Adjust Namespace Manually]; M-->N[Apply Status::On Hold, Set Due Date];
Plan change requests
Plan changes should never be done manually except in the following cases:
- Downgrading to Free.
- Emergency: a next business day follow up is required for the customer to no longer be on a manual plan. The ticket should be passed to L&R or an internal ticket created.
Plan changes on a paid non-trial namespace should be done through a subscription purchase.
If a manual plan change is required for non-emergencies, a legal issue must be created and approved by legal as manually changing a plan causes data discrepancies, can cause legal issues, and can cause bug issues.
Downgrading to a free plan
Before actioning a downgrade request:
- Ensure that the requester provides authorization per the Ownership verification workflow.
- Determine whether they want to pursue a refund. If they do, then follow the refunds workflow.
Example Ticket | Date |
---|---|
ZD Link | 2022-09-02 |
Using customerDot
Important
From CustomerDot you can only change the plan type not the subscription end date.
- From the left side menu click on
customers
and search for the customer. - In the search results click on the GitLab groups icon for the customer you want to update.
- You’ll see a list of groups owned by the customer and you can perform your change here.
If you receive an error, follow the usual troubleshooting procedures in looking up the error in sentry and/or for an existing CustomersDot issue, adding to an existing issue or creating a new one as required.
If you get an error, use admin following the instructions in the next section.
Licensing pathways for handling customer renewals and new sales that have become delayed
In certain scenarios where customer renewals or new customer sales are experiencing delays, the L&R Support process workflows provide flexibility to address these challenges. The following table outlines the options available to issue temporary trial licenses based on specific use cases:
Use Case | Pathway |
---|---|
Customer renewal is taking longer than expected | The sales AE (Account Executive) generates a one-off 21 day temporary renewal extension via SFDC |
Customer renewal exceeds the additional 21 days | The sales AE can open a new Internal Request (IR) ticket with L&R support and request a trial subscription extension for up to 1 month |
Customer renewal exceeds the additional 21 days + 1 month | The sales AE can open a new Internal Request (IR) ticket with L&R support who request approval via the ticket from the senior director of revenue @andrew_murray |
New customer potential sale | The sales AE can request up to 1 month trial extension via an IR with L&R support. |
New customer sale taking longer than 1 month | The sales AE generates a $0 dollar opportunity in SFDC, then opens a new IR ticket with L&R support who request approval via the ticket from the senior director of revenue @andrew_murray |
How to create an NFR (Not for resale) SaaS License
A NFR SaaS ’license’ must begin with either an existing trial or a new trial on a GitLab namespace. Console acccess is then required to convert from trial to an NFR subscription.
How to extend an NFR (Not for resale) SaaS trial using the rails console
To extend a trial SaaS extension.
- The NFR partner needs to either signup for a trial at: https://about.gitlab.com/free-trial/ or start a trial from within their current GitLab namespace.
- Once they have a valid namespace for their trial they need to provide this to support.
- The support engineer requires console access to CustomersDot to GitLab Rails to update the namespace.
- Within the CustomersDot rails console you should execute the command:
view_namespace '<group name space>'
- This will return the partners namespace information and order information. Get the order ‘id’ (i.e. 123456), you will need it for the next command.
- Execute the command to interact with the order id:
o = Order.find 123456
- Review, modify, and execute the following command to update the order:
o.update!(product_rate_plan_id: Plan::ULTIMATE_SAAS_1_YEAR_PLAN, quantity: 25, end_date: Date.parse('2022-11-09'), trial: false)
- View the important info below for what values to substitute as needed
- Execute the command to synchronise the update:
Gitlab::Namespaces::UpdatePlanInfoService.new(o, force_sync: true).execute
- In GitLab.com admin, edit the group and update the Quota of compute minutes to 400. See next step on how to find the admin screen.
- Add an admin note for the group to document the partner has an NFR subscription and link the issue.
Some important information to consider:
- Product_rate_plan_id == the requested NFR plan, it should be
Plan::ULTIMATE_SAAS_1_YEAR_PLAN
orPlan::PREMIUM_SAAS_1_YEAR_PLAN
(no quotes) - Quantity == the ticket submitter will specify this in the issue, it is typically 10 or 25 users
- Trial == must be false otherwise they will be unable to use GitLab shared runners.
- Start date == is the specified in the issue or the date today.
- End date == is one year from specified date or from today’s date.
5fb7706e
)