Environments in Gadget are separate instances of your application. You can have an environment for each team member, set up environments for manual QA testing, or use environments to run automated tests as part of a CI/CD pipeline.
Each environment has its own:
App URL
Database
Server configurations (e.g. API keys, environment variables, client credentials, etc.)
Runs its own version of your application's code
Development vs production environments
There are two main types of environments in Gadget: development and production.
Development environments
Development environments are where you build and make changes to your app. This includes adding data models, writing code, and gives you a sandbox to test your application without impacting production. You can create unlimited development environments.
Development environment frontends
Development environment frontends are served by Vite and include features such as:
This is your live app. Each Gadget app gets one production environment. Once you are satisfied with the changes made in a development environment, you can deploy to production.
Production environment frontends
In the production frontend, Gadget builds minified assets optimized for production and serves them via a high-performance CDN for the best user experience.
Production frontends will be more performant than development environment frontends due to the different Vite bundle configuration. This
is because developer experience is prioritized for development frontends and performance is prioritized for production frontends.
Managing environments
Adding development environments
Click on the environment selector in the Gadget editor
Click + Create a new development environment
Give your environment a name and select an existing environment to clone
What is copied to a new environment?
Cloning an environment copies over everything that can be managed with source control:
data models and schema definitions
code
plugin and connection settings
authorization permissions
app configuration, such as framework version
The following things are not copied to the new environment and are not managed with source control:
data
environment variables
API keys and connected applications
Delete an environment
Go to Settings → General
Locate and select Delete environment for development environments, or Reset environment for production environments
Confirm by entering the name of the environment you are deleting
Deleting an environment will delete all code, data models and data, and configuration for an environment! Make sure you have exported or
migrated any data you want to preserve, and saved any code or configuration using a different environment or source control.
Environment domains and APIs
Your application has separate domains for each environment.
Development domain: https://<your-app>--<your-environment>.gadget.app/
Production domain: https://<your-app>.gadget.app/
To access the frontend or make API requests, use the appropriate domain. For example:
Development GraphQL API: https://<your-app>--<your-environment>.gadget.app/api/graphql
Production GraphQL API: https://<your-app>.gadget.app/api/graphql
Specifying environments using the API client
A Gadget API client can connect to different environments by setting the environment option:
specify environment using the API client
JavaScript
import{Client}from"@gadget-client/your-app";
exportconst api =newClient({
environment:"development",
});
import{Client}from"@gadget-client/your-app";
exportconst api =newClient({
environment:"development",
});
To dynamically switch based on the NODE_ENV:
specify environment using NODE_ENV when using the API client
JavaScript
import{Client}from"@gadget-client/your-app";
// Defaults to development if NODE_ENV is not "production"
exportconst api =newClient();
import{Client}from"@gadget-client/your-app";
// Defaults to development if NODE_ENV is not "production"
exportconst api =newClient();
NODE_ENV will be set to "development" for every development environment. When working with multiple development environments, it is best
to specify the environment manually.
Specifying environments when using a script tag
A script tag can be used to install your app's API client. You must also specify the environment as part of your app's domain when using this script tag.
For example:
use a script tag to install the API client for an environment
Each developer working on the same app should have their own development environment to be used as a personal development sandbox. This prevents any conflicts with other developers working on the same app, and functions the same as building on a local machine.
Gadget's CLI, ggt, can be used to pull down a development environment's code and configuration to a local machine. This enables developers to use source control and branching to manage their applications.
Source control, CI/CD, and suggested deployment workflows can be found in the deployment docs.
Building Shopify or BigCommerce apps as a team
Shopify and BigCommerce app connections are not copied over when creating new environments.
Each developer should create a new Shopify or BigCommerce app and connect it to their development environment.
This will help to reduce noise from webhooks and gives each developer a clean and unique development sandbox.
Multiplayer
Gadget development environments do support multiplayer. This means that two or more developers can build in the same environment at the same time. This is potentially useful for debugging, pair programming, or working on different parts of an application in parallel.
You can see the team members currently working on a single environment in the Gadget editor's environment selector.
Be careful when using multiplayer! Developers have the ability to overwrite each other's code, change branches suddenly, or update
configuration, which may result in lost work if work is not committed to source control regularly.