Sha256: ab9414b05d9319ee5fa2632e4b71c8d1e92a7e0dcee32f865747574cd3faaa09
Contents?: true
Size: 1.59 KB
Versions: 28
Compression:
Stored size: 1.59 KB
Contents
require 'csv' require 'open-uri' require 'time' namespace 'dhatu' do namespace 'import' do namespace 'master_data' do desc "Import all data in sequence" task 'all' => :environment do import_list = ["features"] import_list.each do |item| print "Importing #{item.titleize} \t".yellow begin Rake::Task["dhatu:import:master_data:#{item}"].invoke rescue ArgumentError => e puts "Loading #{item} - Failed - #{e.message}".red rescue Exception => e puts "Importing #{item.titleize} - Failed - #{e.message}".red puts "Backtrace:\n\t#{e.backtrace.join("\n\t")}" end end puts " " end ["Feature"].each do |cls_name| name = cls_name.underscore.pluralize desc "Import #{cls_name.pluralize}" task name => :environment do verbose = true verbose = false if ["false", "f","0","no","n"].include?(ENV["verbose"].to_s.downcase.strip) destroy_all = false destroy_all = true if ["true", "t","1","yes","y"].include?(ENV["destroy_all"].to_s.downcase.strip) path = Rails.root.join('db', 'master_data', "#{cls_name.constantize.table_name}.csv") path = Dhatu::Engine.root.join('db', 'master_data', "#{cls_name.constantize.table_name}.csv") unless File.exists?(path) cls_name.constantize.destroy_all if destroy_all cls_name.constantize.import_data_file(path, true, verbose) # puts "Importing Completed".green if verbose end end end end end
Version data entries
28 entries across 28 versions & 1 rubygems