Self Contained Automated Test Environment
-
Download and install VirtualBox
-
Download and install Vagrant
-
Do a fork of MicroQA project (requires github account for information on how to set up a Github account, refer to the following URL: http://help.github.com/set-up-git-redirect/). On information on how to fork a project, refer to the following link: http://help.github.com/fork-a-repo/.
-
Clone your fork to your local machine.
-
Once inside the repository run "vagrant up". This will download a virtual machine, boot it, and install MicroQA.
-
Login to MicroQA on your browser by visiting: http://localhost:8080
-
Download and install Vagrant
-
Install the Vagrant-AWS plugin:
vagrant plugin install vagrant-aws
-
Do a fork of MicroQA project (requires github account for information on how to set up a Github account, refer to the following URL: http://help.github.com/set-up-git-redirect/). On information on how to fork a project, refer to the following link: http://help.github.com/fork-a-repo/.
-
Clone your fork to your local machine.
-
Edit the following parameters in the Vagrantfile:
aws.access_key_id = "XXXXXXXXXXXXXXXXXX" aws.secret_access_key = "YYYYYYYYYYYYYYYYYYYYYYYYYYYYYYY" aws.instance_type = "m1.medium" ## This CentOS 6 EMI needs to have the following commented out of /etc/sudoers, ## Defaults requiretty aws.ami = "emi-1873419A" aws.security_groups = ["default"] aws.region = "eucalyptus" aws.endpoint = "http://10.0.1.91:8773/services/Eucalyptus" aws.keypair_name = "vic" override.ssh.username ="root" override.ssh.private_key_path ="/Users/viglesias/.ssh/id_rsa"
-
Install a "dummy" vagrant box file to allow override of the box with the ami/emi:
vagrant box add dummy /~https://github.com/mitchellh/vagrant-aws/raw/master/dummy.box
-
Once inside the repository run "vagrant up --provider=aws". This will run a virtual machine, and install MicroQA in your cloud.
-
Login to MicroQA on your browser by visiting: http://<instance-ip>:8080
- Create a test job from the MicroQA Jenkins instance (or edit an existing job)
- Click the New Job link.
- Enter a descriptive job name and use the Copy existing job option to pick a job that is similar to what you want to do (or a new empty job is there are no similar jobs).
- After the job is created, then Configure the job to do what you want it to do.
- Add a description to the job by clicking edit description on the job page. The description should be very clear about what the job does. Make sure that your job's use case is general enough to be useful to other people.
-
Test your job and ensure it's working like you want.
-
From your micro-qa directory login to the instance using the command: "vagrant ssh"
-
Run the command "jenkins-sync" inside the vagrant instance.
-
Exit the vagrant shell then commit your changes to the MicroQA repo.
-
Once your commit is available on GitHub submit a pull request to the upstream repository.
Make sure that each pull request you submit contains a single new job, or fixes to a single job. Try not to combine too many changes in a single pull request.