# awspec [![Gem](https://img.shields.io/gem/v/awspec.svg)](https://rubygems.org/gems/awspec) [![Travis](https://img.shields.io/travis/k1LoW/awspec.svg)](https://travis-ci.org/k1LoW/awspec) [![Scrutinizer](https://img.shields.io/scrutinizer/g/k1LoW/awspec.svg)](https://scrutinizer-ci.com/g/k1LoW/awspec/) [![Gemnasium](https://img.shields.io/gemnasium/k1LoW/awspec.svg)](https://gemnasium.com/k1LoW/awspec) RSpec tests for your AWS resources. [Resource Types](doc/resource_types.md) ## Installation Add this line to your application's Gemfile: ```ruby gem 'awspec' ``` And then execute: $ bundle Or install it yourself as: $ gem install awspec ## Getting Started ### 1. Generate awspec init files $ awspec init ### 2. Set AWS credentials #### 2-1. Use Shared Credentials ```sh $ aws configure ... $ export AWS_REGION='ap-northeast-1' ``` #### 2-2. Use spec/secrets.yml ```sh $ cat < spec/secrets.yml region: ap-northeast-1 aws_access_key_id: XXXXXXXXXXXXXXXXXXXX aws_secret_access_key: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX EOF ``` ### 3. Write spec/*_spec.rb ```ruby describe ec2('my-ec2-tag-name') do it { should be_running } its(:instance_id) { should eq 'i-ec12345a' } its(:image_id) { should eq 'ami-abc12def' } its(:public_ip_address) { should eq '123.0.456.789' } it { should have_security_group('my-security-group-name') } it { should belong_to_vpc('my-vpc') } it { should belong_to_subnet('subnet-1234a567') } it { should have_eip('123.0.456.789') } end ``` ### 4. Run tests $ bundle exec rake spec ### Advanced Usage: Spec generate command Generate spec from AWS resources already exists. ```sh $ awspec generate ec2 vpc-ab123cde >> spec/ec2_spec.rb ``` ## Support AWS Resources - [x] EC2 (`ec2`) - [x] RDS (`rds`) - [x] RDS DB Parameter Group (`rds_db_parameter_group`) - [x] Security Group (`security_group`) - [x] VPC (`vpc`) - [x] S3 (`s3`) - Route53 - [x] Route53 Hosted Zone (`route53_hosted_zone`) - AutoScaling - [x] Auto Scaling Group (`auto_scaling_group`) - [x] Subnet (`subnet`) - [x] RouteTable (`route_table`) - [x] EBS Volume (`ebs`) - [x] ELB (`elb`) - [x] Lambda (`lambda`) - IAM - [x] IAM User (`iam_user`) - [x] IAM Group (`iam_group`) - [x] IAM Role (`iam_role`) - [x] IAM Policy (`iam_policy`) [Resource Types more infomation here](doc/resource_types.md) ### Next..? - [ ] ElastiCache - [ ] CloudWatch - ... ## Contributing 1. Fork it ( https://github.com/k1LoW/awspec/fork ) 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Add some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Create a new Pull Request ### How to add new resource type (ex. Redshift resource) 1. Create your feature branch (`git checkout -b add-type-redshift`) 2. Generate template files (`bundle exec ./lib/awspec/bin/toolbox template redshift`) 3. Fill files with code. 4. Generate [doc/resource_types.md](doc/resource_types.md) (`bundle exec ./lib/awspec/bin/toolbox docgen > doc/resource_type.md`) 5. Run test (`bundle exec rake spec`) 6. Push to the branch (`git push origin add-type-redshift`) 7. Create a new Pull Request ## References awspec is inspired by Serverspec. - Original idea (code / architecture) -> [Serverspec](https://github.com/serverspec/serverspec) - `AWS + Serverspec` original concept -> https://github.com/marcy-terui/awspec - [Serverspec book](http://www.oreilly.co.jp/books/9784873117096/)