GitXplorerGitXplorer
a

separatum

public
2 stars
0 forks
0 issues

Commits

List of commits on branch master.
Verified
55d39dea1c455d683731cd129b412436a4da029b

Merge pull request #1 from a0s/dependabot/bundler/rake-tw-13.0

aa0s committed 4 years ago
Verified
4b8bb752171f4189461aa21ad8d3a081b2658430

Update rake requirement from ~> 10.0 to ~> 13.0

ddependabot[bot] committed 5 years ago
Verified
9c8bb0ca59be0d17f98f663cee70fa67c9161d37

Update README.md

aa0s committed 6 years ago
Verified
988121824e946f1c10df50d409020553daa02f09

Update README.md

aa0s committed 6 years ago
Unverified
6f8ca05f1861b8068d13838212524b6205949896

Bump version

committed 6 years ago
Unverified
a8813e145bb1b11f952d5d951bd00db53d72bf1a

Add time machine

committed 6 years ago

README

The README file for this repository.

(WIP) Separatum

Extract and transfer linked objects from one database into another.

How you can use it

  • Making seeds.rb as copy of production data for testing purposes
  • Making separate database for AB-testing (performance or marketing purposes)
  • Checking your data logical structure (it will raise on broken or unexisting links)
  • Freeze state of a set of objects in time and export them as Object.create ruby-code

UUID

It is better if you are using UUID primary key in every table you want to extract. This will allow you to avoid problems (with primary keys and sequences) during importing objects into a new database. Also UuidChanger can help you avoid collisions in case of importing same objects more than one time in the same database.

Examples

gem install separatum
require 'separatum'

Extract and export

Build new exporter

exporter = Separatum.build do
  use Separatum::Importers::ActiveRecord  # We are going to crawl ActiveRecord objects  
  use Separatum::Processors::UuidChanger  # Hide production's UUIDs with no broken links 
  use Separatum::Exporters::JsonFile, file_name: 'separate.json' # Export object to json file                                      
end

Define start object and extract all linked records into separate.json file

start_object = User.find('any_uuid_from_your_table')
exporter.(start_object)

Import into new database

Build new importer

importer = Separatum.build do
  use Separatum::Importers::JsonFile, file_name: 'separate.json' # We are going to import hashed objects from separate.json  
  use Separatum::Exporters::ActiveRecord # Save them (in one transaction for all objects in set)
end

Import records to a database from separate.json file

importer.() # It returns set of persisted objects

Extract and generate ruby code

seeds_generator = Separatum.build do
  use Separatum::Importers::ActiveRecord
  use Separatum::Processors::UuidChanger  
  use Separatum::Exporters::ActiveRecordCode
end

Return generated ruby code for creating objects in a database

start_object = User.find('any_uuid_you_want_to_start_from')
puts seeds_generator.(start_object)

Building parts

Separatum::Importers::ActiveRecord

Parameters:

  • max_depth (default: 3)
  • edge_classes
  • denied_classes
  • denied_class_transitions
  • svg_file_name
  • dot_file_name

Separatum::Importers::JsonFile

Parameters:

  • file_name

Separatum::Processors::FieldChanger

Parameters:

  • 1st/2nd - class and field to change
  • 3rd/4th - class and method that will make transformation
  • 3rd - Proc or Block

Separatum::Exporters::ActiveRecord

Separatum::Exporters::ActiveRecordCode

Parameters:

  • file_name
  • ignore_not_unique_classes

Separatum::Exporters::JsonFile

Parameters:

  • file_name
  • pretty_print

TODO

  • Better README.md :)

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.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/a0s/separatum.

License

The gem is available as open source under the terms of the MIT License.