Sha256: d1eac3940077add2a56519f097b4e46e158fdcce789c8c0423ed988fa8c7eb39
Contents?: true
Size: 1.83 KB
Versions: 5
Compression:
Stored size: 1.83 KB
Contents
require_relative 'schema' require_relative 'error' require_relative 'hash_util' require_relative 'bigquery_wrapper' class BigqueryMigration class Action attr_reader :config, :opts def initialize(config, opts = {}) @config = HashUtil.deep_symbolize_keys(config) @opts = HashUtil.deep_symbolize_keys(opts) @action = @config[:action] unless self.class.supported_actions.include?(@action) raise ConfigError, "Action #{@action} is not supported" end end def run begin success = true result = send(@action) rescue => e result = { error: e.message, error_class: e.class.to_s, error_backtrace: e.backtrace } success = false ensure success = false if result[:success] == false end [success, result] end def self.supported_actions Set.new(%w[ create_dataset create_table delete_table patch_table migrate_table insert preview ]) end def client @client ||= BigqueryMigration.new(@config, @opts) end def create_dataset client.create_dataset end def create_table client.create_table(columns: config[:columns]) end def delete_table client.delete_table end def patch_table client.patch_table( columns: config[:columns], add_columnss: config[:add_columnss] ) end def migrate_table client.migrate_table( schema_file: config[:schema_file], columns: config[:columns], backup_dataset: config[:backup_dataset], backup_table: config[:backup_table] ) end def insert client.insert_all_table_data(rows: config[:rows]) end def preview client.list_table_data(max_results: config[:max_results]) end end end
Version data entries
5 entries across 5 versions & 1 rubygems