# AnonymousActiveRecord This library was 🎩 inspired by 🎩, the [Wolverine project](https://github.com/mcary/wolverine), which [implemented a clever workaround](https://github.com/mcary/wolverine/commit/fa27fa2cc485b2fa83d71b2045ba5a0a069dba75) to the official non-support of [anonymous classes by ActiveRecord](https://github.com/rails/rails/issues/8934). Warning: Use of this gem is a **security risk**, due to the use of Ruby's `eval`. It is intended for use in a test suite, or other non-critical environment. | Project | AnonymousActiveRecord | |------------------------ | ----------------------- | | gem name | [anonymous_active_record](https://rubygems.org/gems/anonymous_active_record) | | license | [![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://opensource.org/licenses/MIT) | | download rank | [![Downloads Today](https://img.shields.io/gem/rd/anonymous_active_record.svg)](https://github.com/pboling/anonymous_active_record) | | version | [![Version](https://img.shields.io/gem/v/anonymous_active_record.svg)](https://rubygems.org/gems/anonymous_active_record) | | dependencies | [![Depfu](https://badges.depfu.com/badges/272ce0df3bc6df5cbea9354e2c3b65af/count.svg)](https://depfu.com/github/pboling/anonymous_active_record?project_id=5614) | | continuous integration | [![Build Status](https://travis-ci.org/pboling/anonymous_active_record.svg?branch=master)](https://travis-ci.org/pboling/anonymous_active_record) | | test coverage | [![Test Coverage](https://api.codeclimate.com/v1/badges/fe504d4ab2fb77cecf7d/test_coverage)](https://codeclimate.com/github/pboling/anonymous_active_record/test_coverage) | | maintainability | [![Maintainability](https://api.codeclimate.com/v1/badges/fe504d4ab2fb77cecf7d/maintainability)](https://codeclimate.com/github/pboling/anonymous_active_record/maintainability) | | code triage | [![Open Source Helpers](https://www.codetriage.com/pboling/anonymous_active_record/badges/users.svg)](https://www.codetriage.com/pboling/anonymous_active_record) | | FOSSA Licenses | [![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fpboling%2Fanonymous_active_record.svg?type=shield)](https://app.fossa.io/projects/git%2Bgithub.com%2Fpboling%2Fanonymous_active_record?ref=badge_shield) | | homepage | [on Github.com][homepage], [on Railsbling.com][blogpage] | | documentation | [on RDoc.info][documentation] | | Spread ~β™‘β“›β“žβ“₯β“”β™‘~ | [🌍 🌎 🌏](https://about.me/peter.boling), [🍚](https://www.crowdrise.com/helprefugeeswithhopefortomorrowliberia/fundraiser/peterboling), [βž•](https://plus.google.com/+PeterBoling/posts), [πŸ‘Ό](https://angel.co/peter-boling), [πŸ›](https://www.topcoder.com/members/pboling/), [:shipit:](http://coderwall.com/pboling), [![Tweet Peter](https://img.shields.io/twitter/follow/galtzo.svg?style=social&label=Follow)](http://twitter.com/galtzo) | ## Installation Add this line to your application's Gemfile: ```ruby gem 'anonymous_active_record' ``` And then execute: $ bundle Or install it yourself as: $ gem install anonymous_active_record ## Usage Require the library in your `spec_helper` or other test suite boot file. ```ruby require 'anonymous_active_record' ``` Let's say you want to write specs for a module, `HasBalloon`, which provides a method `has_balloon?`, and will be mixed into ActiveRecord classes. ```ruby module HasBalloon def has_balloon? name == 'Spot' ? true : false # only Spot has a balloon end end ``` This won't work [(really!)](https://github.com/rails/rails/issues/8934): ```ruby let(:ar_with_balloon) do Class.new(ActiveRecord::Base) do attr_accessor :name include HasBalloon def flowery_name "#{b_f}#{name}#{b_f}" end def b_f has_balloon? ? '🎈' : '🌸' end end end ``` So do this instead: ```ruby let(:ar_with_balloon) do AnonymousActiveRecord.generate(columns: ['name']) do include HasBalloon def flowery_name "#{b_f}#{name}#{b_f}" end def b_f has_balloon? ? '🎈' : '🌸' end end end it 'can test the module' do expect(ar_with_balloon.new(name: 'Spot').flowery_name).to eq('🎈Spot🎈') expect(ar_with_balloon.new(name: 'Not Spot').flowery_name).to eq('🌸Not Spot🌸') end ``` ### Generate Options ```ruby AnonymousActiveRecord.generate( table_name: 'a_table_name', # if table_name is not set klass_basename will be used to derive a unique random table_name # default is a unique random table name klass_basename: 'anons', # is default columns: ['name'], # columns default is [], # meaning class will have ['id', 'created_at', 'updated_at'], as the AR defaults # Optionally provide an array of hashes and thereby designate column type: # [{name: 'name', type: 'string'}, {name: 'baked_at', type: 'time'}] timestamps: true, # is default indexes: [{columns: ['name'], unique: true}], # indexes default is [], # meaning class will have no indexes, as the AR defaults # Optionally provide an array of hashes of index options (similar to those used in Rails migrations): # [{columns: ['name'], unique: true}, {columns: ['baked_at']}] connection_params: { adapter: 'sqlite3', encoding: 'utf8', database: ':memory:' } # is default ) do # code which becomes part of the class definition end ``` The block is optional. ### Factory Options ```ruby AnonymousActiveRecord.factory( source_data: [{name: 'Phil'}, {name: 'Vickie'}], # Array of hashes, where each hash represents a record that will be created # ... The rest of the options are the same as for generate, see above. ) do # same as for generate, see above. end ``` The block is optional. There is also a `factory!` method that will raise if the create fails, accomplished by calling `create!` instead of `create`. ## Development After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment. To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org). ## Contributing Bug reports and pull requests are welcome on GitHub at https://github.com/pboling/anonymous_active_record. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct. ## Code of Conduct Everyone interacting in the AnonymousActiveRecord project’s codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/pboling/anonymous_active_record/blob/master/CODE_OF_CONDUCT.md). ## Versioning This library aims to adhere to [Semantic Versioning 2.0.0][semver]. Violations of this scheme should be reported as bugs. Specifically, if a minor or patch version is released that breaks backward compatibility, a new version should be immediately released that restores compatibility. Breaking changes to the public API will only be introduced with new major versions. As a result of this policy, you can (and should) specify a dependency on this gem using the [Pessimistic Version Constraint][pvc] with two digits of precision. For example: ```ruby spec.add_dependency 'anonymous_active_record', '~> 0.0' ``` ## License * Copyright (c) 2018 [Peter H. Boling][peterboling] of [Rails Bling][railsbling] [![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://opensource.org/licenses/MIT) [![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fpboling%2Fanonymous_active_record.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2Fpboling%2Fanonymous_active_record?ref=badge_large) [license]: LICENSE [semver]: http://semver.org/ [pvc]: http://guides.rubygems.org/patterns/#pessimistic-version-constraint [railsbling]: http://www.railsbling.com [peterboling]: http://www.peterboling.com [documentation]: http://rdoc.info/github/pboling/anonymous_active_record/frames [homepage]: https://github.com/pboling/anonymous_active_record/ [blogpage]: http://www.railsbling.com/tags/anonymous_active_record/