mock-aws-s3¶ ↑
This is a simple gem for mocking out the AWS::S3 library, so that no calls to the Amazon S3 service during tests.
Usage is simple, just add the gem to your bundle, and require it in your spec_helper.rb:
require 'mock-aws-s3'
From there on, all (supported) calls to AWS::S3::S3Object will be proxied to file operations in a temp directory on your disk. So these commands:
AWS::S3::S3Object.store 'key', 'some data', 'bucket' AWS::S3::S3Object.exists?('key', 'bucket') AWS::S3::S3Object.value 'key', 'bucket' AWS::S3::S3Object.url_for 'key', 'bucket' AWS::S3::S3Object.delete('key', 'bucket')
… will result in a file being created on disk at ./tmp/mock-aws-s3/bucket/key, with contents: "some data".  A File.exists?() check will be performed on that file, the content of the file will be returned, a local file uri will be return and then it will be deleted.
If you are using Rails, the Rails.root directory will be used: Rails.root.join('tmp').
Note on Patches/Pull Requests¶ ↑
- 
Fork the project. 
- 
Make your feature addition or bug fix. 
- 
Add spec for it. This is important so I don’t break it in a future version unintentionally. 
- 
Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull) 
- 
Send me a pull request. Bonus points for topic branches. 
Copyright¶ ↑
Copyright © 2010 Joshua Krall. See LICENSE for details.