/vagrant-solidus

Vagrant plugin for Solidus sites development

Primary LanguageRubyMIT LicenseMIT

Vagrant plugin for Solidus sites development

This is a Vagrant plugin that adds a Solidus provisioner and command to manage Solidus sites. It enables you to easily create, run and update Solidus sites in the virtual machine without having to setup or log into the machine itself, through the vagrant command line interface.

Getting Started

VirtualBox is a free cross-platform virtualization app that makes it easy to simultaneously run multiple operating systems on your machine. In our usage it is merely a provider for Vagrant.

Vagrant layers provisioning, file-based configuration, and a command-line interface on top of VirtualBox. This provides disposable, consistent environments for running development servers. Synced Folders and Networking features make the development experience the same as if running in your own environment: your own tools and whatever ports you’d like for access via your browser and other clients.

Install Pow (Mac only)

Among other things, Pow enables port proxying on your Mac, to let you route all web traffic on a particular hostname to another port on your computer. So you'll be able to access your site on http://sitename.dev instead of http://localhost:8081 or http://lvh.me:8081. No need to remember weird urls with changing port numbers! Install Anvil to get a handy menubar extra showing all of your Pow-powered hosts. This plugin will automatically configure Pow for your sites, if it is installed.

Create the Vagrant environment

Using this plugin, you can easily create a Vagrantfile ready for Solidus:

$ vagrant plugin install vagrant-solidus
$ mkdir solidus
$ cd solidus
$ vagrant solidus-box init

Up!

You are now ready to start the virtual machine:

$ vagrant up

This will boot the VM, and automatically install and configure everything that is required to run Solidus sites, a process called Provisioning: Vagrantfile defines a pre-built 64-bit Ubuntu 12.04.3 LTS (Precise) “box” provided by the Vagrant team. This file also defines basic configuration such as port mapping and synced folder locations, it can be updated at any time. New boxes are only downloaded to your machine the first time you provision a new VM however. Once the operating system is booted, this plugin will perform additional provisioning. You can redo the provisioning process at any time by running vagrant provision.

At this point, you are ready to work on your Solidus site!

Development Process

A number of ports are automatically opened and forwarded to the virtual machine: 8081 to 8095 for the Solidus sites, and 35730 to 35744 for LiveReload. Whenever a site is started, two ports will be used for that site, so you can load them on your local browser.

A new site Vagrant command has been added to help create and manage your Solidus sites. To see all available sub-commands:

$ vagrant site

For help on a specific command, use the -h argument. For example:

$ vagrant site create -h

Creating a site

The easiest way to create a new Solidus site is to use the handy Solidus site template. And the easiest way to do that is to use the following command:

$ vagrant site create my-site

This will create a new sub-directory called my-site, initialized with a new site based on the latest Solidus site template. Another option is to create the directory and site yourself, from the ground up.

Adding an existing site

To work on an existing Solidus site, copy it or clone it to a sub-directory of this repo. The name of the site will be the name of that sub-directory.

Starting a site

Once the site has been added, start the Solidus server (which will run within the virtual machine) with this command:

$ cd my-site
$ vagrant site start

You can now access the website on http://my-site.dev if you installed Pow. If not, look at the start command's output, the site's urls will have been displayed. Note that many sites can run at the same time.

Hint: Site files are actually stored on your machine, not in the virtual machine. You can edit them as usual, and the server will load them from your machine. Stopping or deleting the virtual machine will not affect your files.

package.json

In order for a site to be started by this plugin, it only needs one thing: a package.json file, with a dependency on Solidus. Two optional scripts can also be added to the package.json file:

  • build: called when the site is started, for example to compile sass files
  • watch: called when the site is started, to automatically recompile the assets when they change

See the solidus-site-template's package.json for an example.

Node and npm versions

By default, vagrant-solidus will use Node version stable and npm version ^2.0.0. To use different versions, specify them in the package.json engines field.

Site installation steps

When a site is started with vagrant site start, the following steps are executed:

  • If the site has a Gemfile file, the bundle is installed, else only the sass gem is installed
  • If the site has a bower.json file, the bower packages are installed
  • The site's npm packages are installed
  • The site's assets are compiled (see package.json): npm --port=PORT --livereloadport=PORT --logserverport=PORT run build
  • The site's assets are watched (see package.json): npm --port=PORT --livereloadport=PORT --logserverport=PORT run watch
  • The site is started, by calling the site's local solidus bin: ./node_modules/.bin/solidus start --dev --loglevel=3 --port=PORT --livereloadport=PORT --logserverport=PORT

Stopping a site

$ vagrant site stop

Restarting a site

$ vagrant site restart

Updating a site

As the Solidus and Solidus site templates projects progress, you'll probably want to update your sites to use the latest versions of those repos. This is done with the update command:

$ vagrant site update

Note that this command will modify some of your site files. Make sure to review all changes applied to your files before committing those changes.

Running command line commands

If you need to run custom commands for your site, for example Grunt tasks, you will need to run them in the VM itself.

Hard way (ssh into the VM and run your commands):

$ vagrant ssh
$ cd my-site
$ grunt my-task --option=something
$ exit

Easy way (use the run command):

$ vagrant site run grunt my-site --option=something

Are my sites running?

$ vagrant site status

Debugging a site

Run this command to follow the site's log:

$ vagrant site log

Deleting a site

Warning: you will obviously lose your local site files!

$ vagrant site stop
$ cd ..
$ rm -rf my-site

Managing the VM

To stop the virtual machine, run:

$ vagrant halt

See the CLI docs for other commands.

Updating

To use the latest version of vagrant-solidus, simply update the plugin and re-initialize your Vagrantfile:

$ vagrant halt
$ vagrant plugin update vagrant-solidus
$ vagrant solidus-box init
$ vagrant up

Installing a Specific Version

To use a specific version of vagrant-solidus, you can do the following;

$ vagrant halt
$ vagrant plugin uninstall vagrant-solidus
$ vagrant plugin install vagrant-solidus --plugin-version 1.0.0.rc1
$ vagrant solidus-box init
$ vagrant up

Replacing 1.0.0.rc1 with the version number you want.

Troubleshooting

Windows: 'ssh' executable not found

Vagrant needs an ssh.exe executable to log into the virtual machine when running vagrant ssh. Windows doesn't provide such an executable by default, but Git does. The easiest way to fix this problem is by adding Git's bin path to the system's PATH environment variable. In the Start menu, search for "system environment variables". Then locate the PATH system environment variable, click Edit and add Git's bin path (probably located in C:\Program Files (x86)\Git\bin). Note that you will need to restart your Command Prompt for the changes to take effect. Also, note that Git's own executables like find.exe will be now be used instead of Windows' default executables.

Resetting the VM

If your virtual machine is in a weird state, the simplest solution is sometimes to rebuild it. All you need to do is destroy the VM and rebuild. This process will not delete your sites files, since they are hosted on your machine, not in the virtual machine.

$ vagrant destroy
$ vagrant up

Adding or changing the forwarded ports

When a site is started, it requires 3 forwarded ports for the Solidus server, the log server and LiveReload. By default, 45 ports are forwarded when the box is started. Once a site has been started, its used ports will be reserved for later use. If you run out of ports, or if a default port is already used by another application on your machine, you can manage them directly in the Vagrantfile, with the following config variables, which should be arrays of available ports. Note that the box should be reloaded if those values are changed.

  • config.solidus.site_ports
  • config.solidus.livereload_ports
  • config.solidus.log_server_ports

It's also possible to remove ports reserved by older unused sites. The reserved ports are listed in this file: .vagrant-solidus/data/sites.json.