flydata 0.7.2 → 0.7.2.1

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: b4388aaa10ad1cba39ffe66fa6b6db2fed3e5268
4
- data.tar.gz: 91dfd8a833cc5f3b4b8e47d72e9276e58fc8212a
3
+ metadata.gz: 041b42f8c7a79544e1075015c40b5f4d617eb983
4
+ data.tar.gz: 18a938ab66c2754e67821cdb93178f0450991d8d
5
5
  SHA512:
6
- metadata.gz: 0f88c6786e5ab53a363c486d2d43def69b4b861f8da830de2cad0dd884f27f9b328792c8633c32b76fedc245979cc660977b59840434e3ef3ec3ddafa4c10547
7
- data.tar.gz: 4db0d551a501458a49c7386919f827ed6961dddd737ac82c20eb096f6c3d192c125e7045e027f462d8caf1ea106c84db8711a66abae024929382bb8888cba627
6
+ metadata.gz: 0afce08535788fde831998db168317d125ab4e4249f36dd9d10fee443ca3e62bb3dfce478bc3953e04d5d57dd7fa560e4ba2a1948c517021378f52a0686abc58
7
+ data.tar.gz: e7af6dd1ec9470fd25a5c853858123112deb8f90c1a7543d09dc99c5564d75398c63f934125906f29bbf91b53d8cc8fa923f014b32c7b164f7554bf0058b44bd
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.7.2
1
+ 0.7.2.1
@@ -56,7 +56,7 @@ class RedshiftTableDef
56
56
  options[:backup_postfix] = "_flydata#{Time.now.strftime('%Y%m%d%H%M%S')}"
57
57
  tabledef += "BEGIN;\n"
58
58
  tabledef += remove_table_sql(flydata_tabledef, schema_name, options) unless options[:ctl_only]
59
- tabledef += create_table_sql(flydata_tabledef, schema_name) unless options[:ctl_only]
59
+ tabledef += create_table_sql(flydata_tabledef, schema_name, options) unless options[:ctl_only]
60
60
  tabledef += comment_sql(flydata_tabledef, schema_name) unless options[:ctl_only]
61
61
  tabledef += flydata_ctl_sql(flydata_tabledef, schema_name)
62
62
  tabledef += "COMMIT;\n"
@@ -167,7 +167,7 @@ EOS
167
167
  sql += drop_backup_table_sql(flydata_tabledef, schema_name, options)
168
168
  # create an empty table to prevent RENAME TABLE query from failing
169
169
  sql += create_table_sql(flydata_tabledef, schema_name,
170
- create_table_sql: CREATE_TABLE_IF_NOT_EXISTS_SQL)
170
+ options.merge(create_table_sql: CREATE_TABLE_IF_NOT_EXISTS_SQL))
171
171
  backup_tbl = table_name_for_ddl(
172
172
  "#{table_name}#{options[:backup_postfix]}", nil)
173
173
  sql += RENAME_TABLE_SQL % [redshift_tbl, backup_tbl]
@@ -194,6 +194,13 @@ EOS
194
194
  ct_sql = options[:create_table_sql] || CREATE_TABLE_SQL
195
195
  lines = flydata_tabledef[:columns].collect{|column| column_def_sql(column) }
196
196
  pk_def = primary_key_sql(flydata_tabledef)
197
+
198
+ unless options[:skip_primary_key_check]
199
+ unless pk_def
200
+ $log.error "no primary key defined in table: #{flydata_tabledef[:table_name]}"
201
+ raise "no primary key defined"
202
+ end
203
+ end
197
204
  lines << pk_def if pk_def
198
205
 
199
206
  contents = lines.join(",\n")
@@ -403,6 +403,33 @@ describe PostgresqlTableDef do
403
403
  end
404
404
  end
405
405
  end
406
+
407
+ describe '.parse_one_column_def' do
408
+ subject {described_class.parse_one_column_def(information_schema_column)}
409
+ let(:information_schema_column) { {} }
410
+ let(:type) { double('type') }
411
+ before do
412
+ information_schema_column["is_primary"] = is_primary
413
+ allow(described_class).to receive(:convert_to_flydata_type).
414
+ with(information_schema_column).
415
+ and_return(type)
416
+ end
417
+
418
+ context 'when the column is primary key' do
419
+ let(:is_primary) { 't' }
420
+ it { expect(subject[:primary_key]).to eq true}
421
+ end
422
+
423
+ context 'when the column is index key' do
424
+ let(:is_primary) { 'f' }
425
+ it { expect(subject[:primary_key]).to eq nil}
426
+ end
427
+
428
+ context 'when the column is not primary key or index key' do
429
+ let(:is_primary) { nil }
430
+ it { expect(subject[:primary_key]).to eq nil}
431
+ end
432
+ end
406
433
  end
407
434
 
408
435
  end
Binary file
@@ -1184,7 +1184,7 @@ EOM
1184
1184
  flydata_tabledefs.each do |flydata_tabledef|
1185
1185
  skip_drop_table = opts.drop_append_only? ? false : append_only.include?(flydata_tabledef[:table_name])
1186
1186
  puts FlydataCore::TableDef::SyncRedshiftTableDef.from_flydata_tabledef(flydata_tabledef,
1187
- flydata_ctl_table: create_flydata_ctl_table, schema_name: schema_name, ctl_only: opts.ctl_only?, skip_drop_table: skip_drop_table)
1187
+ flydata_ctl_table: create_flydata_ctl_table, schema_name: schema_name, ctl_only: opts.ctl_only?, skip_drop_table: skip_drop_table, skip_primary_key_check: opts.skip_primary_key_check?)
1188
1188
  create_flydata_ctl_table = false
1189
1189
  end
1190
1190
  table_validity_hash = {}
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: flydata
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.2
4
+ version: 0.7.2.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Koichi Fujikawa
@@ -12,7 +12,7 @@ authors:
12
12
  autorequire:
13
13
  bindir: bin
14
14
  cert_chain: []
15
- date: 2016-04-12 00:00:00.000000000 Z
15
+ date: 2016-04-21 00:00:00.000000000 Z
16
16
  dependencies:
17
17
  - !ruby/object:Gem::Dependency
18
18
  name: rest-client