hbase-jruby 0.3.0-java → 0.3.1-java
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG.md +6 -0
- data/lib/hbase-jruby/row.rb +7 -2
- data/lib/hbase-jruby/schema.rb +17 -2
- data/lib/hbase-jruby/version.rb +1 -1
- data/test/test_schema.rb +22 -0
- metadata +15 -21
data/CHANGELOG.md
CHANGED
data/lib/hbase-jruby/row.rb
CHANGED
@@ -37,9 +37,12 @@ class Row
|
|
37
37
|
def to_h
|
38
38
|
HASH_TEMPLATE.clone.tap do |ret|
|
39
39
|
@result.getNoVersionMap.each do |cf, cqmap|
|
40
|
+
cf = cf.to_s
|
40
41
|
cqmap.each do |cq, val|
|
41
42
|
f, q, t = @table.lookup_schema(cq.to_s)
|
42
|
-
|
43
|
+
t = nil if f != cf
|
44
|
+
name = t ? q : [cf.to_sym, ByteArray[cq]]
|
45
|
+
|
43
46
|
ret[name] = Util.from_bytes(t, val)
|
44
47
|
end
|
45
48
|
end
|
@@ -51,9 +54,11 @@ class Row
|
|
51
54
|
def to_H
|
52
55
|
HASH_TEMPLATE.clone.tap do |ret|
|
53
56
|
@result.getMap.each do |cf, cqmap|
|
57
|
+
cf = cf.to_s
|
54
58
|
cqmap.each do |cq, tsmap|
|
55
59
|
f, q, t = @table.lookup_schema(cq.to_s)
|
56
|
-
|
60
|
+
t = nil if f != cf
|
61
|
+
name = t ? q : [cf.to_sym, ByteArray[cq]]
|
57
62
|
|
58
63
|
ret[name] =
|
59
64
|
Hash[
|
data/lib/hbase-jruby/schema.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
require 'forwardable'
|
2
|
+
require 'set'
|
2
3
|
|
3
4
|
class HBase
|
4
5
|
class Schema
|
@@ -35,7 +36,7 @@ class Schema
|
|
35
36
|
# CF:CQ => Type shortcut
|
36
37
|
cf = cf.to_s
|
37
38
|
if cf.index(':')
|
38
|
-
cf, q =
|
39
|
+
cf, q = cf.to_s.split ':', 2
|
39
40
|
cols = { q => cols }
|
40
41
|
else
|
41
42
|
raise ArgumentError, "invalid schema: expected Hash" unless cols.is_a?(Hash)
|
@@ -43,7 +44,10 @@ class Schema
|
|
43
44
|
|
44
45
|
# Family => { Column => Type }
|
45
46
|
cols.each do |cq, type|
|
46
|
-
|
47
|
+
type = type.to_sym
|
48
|
+
unless KNOWN_TYPES.include? type
|
49
|
+
raise ArgumentError, "invalid schema: unknown type: #{type}"
|
50
|
+
end
|
47
51
|
|
48
52
|
# Pattern
|
49
53
|
case cq
|
@@ -110,6 +114,17 @@ private
|
|
110
114
|
}
|
111
115
|
end
|
112
116
|
|
117
|
+
KNOWN_TYPES = Set[
|
118
|
+
:string, :str, :symbol, :sym,
|
119
|
+
:byte,
|
120
|
+
:boolean, :bool,
|
121
|
+
:int,
|
122
|
+
:short,
|
123
|
+
:long, :fixnum,
|
124
|
+
:float, :double,
|
125
|
+
:bigdecimal,
|
126
|
+
:raw
|
127
|
+
]
|
113
128
|
end
|
114
129
|
end
|
115
130
|
|
data/lib/hbase-jruby/version.rb
CHANGED
data/test/test_schema.rb
CHANGED
@@ -12,6 +12,14 @@ class TestSchema < TestHBaseJRubyBase
|
|
12
12
|
@hbase.schema.delete @table.name
|
13
13
|
end
|
14
14
|
|
15
|
+
def test_invalid_schema_type
|
16
|
+
@hbase.schema = { @table.name => { :cf1 => { :a => 'string' } } }
|
17
|
+
|
18
|
+
assert_raise(ArgumentError) do
|
19
|
+
@hbase.schema = { @table.name => { :cf1 => { :a => :xxx } } }
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
15
23
|
def test_schema
|
16
24
|
@hbase.schema = {
|
17
25
|
@table.name => {
|
@@ -27,6 +35,7 @@ class TestSchema < TestHBaseJRubyBase
|
|
27
35
|
|
28
36
|
# cf3:f is a 8-byte integer
|
29
37
|
:cf3 => { :f => :fixnum },
|
38
|
+
'cf3:g' => :float
|
30
39
|
}
|
31
40
|
}
|
32
41
|
|
@@ -98,6 +107,19 @@ class TestSchema < TestHBaseJRubyBase
|
|
98
107
|
assert_equal 2, @table.filter( 'a' => 50..110).count
|
99
108
|
assert_equal 2, @table.filter( :a => 50..110).count
|
100
109
|
assert_equal 1, @table.filter(:a => { :gt => 150 }).count
|
110
|
+
|
111
|
+
# cf:g (automatic type conversion)
|
112
|
+
@table.put 3, :g => 3.14
|
113
|
+
assert_equal 3.14, @table.get(3)[:g]
|
114
|
+
@table.put 3, :g => 314
|
115
|
+
assert_equal 314, @table.get(3)[:g]
|
116
|
+
|
117
|
+
# cf3:g vs. cf2:g
|
118
|
+
@table.put 4, :g => 3.14, 'cf2:g' => 'String'
|
119
|
+
assert_equal 3.14, @table.get(4)[:g]
|
120
|
+
assert_equal 'String', @table.get(4)['cf2:g'].to_s
|
121
|
+
assert_equal 3.14, @table.get(4).to_h[:g]
|
122
|
+
assert_equal 'String', @table.get(4).to_h['cf2:g'].to_s
|
101
123
|
end
|
102
124
|
|
103
125
|
def test_schema_readme
|
metadata
CHANGED
@@ -2,30 +2,28 @@
|
|
2
2
|
name: hbase-jruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
4
|
prerelease:
|
5
|
-
version: 0.3.
|
5
|
+
version: 0.3.1
|
6
6
|
platform: java
|
7
7
|
authors:
|
8
8
|
- Junegunn Choi
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2013-05-
|
12
|
+
date: 2013-05-22 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: test-unit
|
16
16
|
version_requirements: !ruby/object:Gem::Requirement
|
17
17
|
requirements:
|
18
|
-
- -
|
18
|
+
- - '>='
|
19
19
|
- !ruby/object:Gem::Version
|
20
|
-
version:
|
21
|
-
MA==
|
20
|
+
version: '0'
|
22
21
|
none: false
|
23
22
|
requirement: !ruby/object:Gem::Requirement
|
24
23
|
requirements:
|
25
|
-
- -
|
24
|
+
- - '>='
|
26
25
|
- !ruby/object:Gem::Version
|
27
|
-
version:
|
28
|
-
MA==
|
26
|
+
version: '0'
|
29
27
|
none: false
|
30
28
|
prerelease: false
|
31
29
|
type: :development
|
@@ -33,17 +31,15 @@ dependencies:
|
|
33
31
|
name: simplecov
|
34
32
|
version_requirements: !ruby/object:Gem::Requirement
|
35
33
|
requirements:
|
36
|
-
- -
|
34
|
+
- - '>='
|
37
35
|
- !ruby/object:Gem::Version
|
38
|
-
version:
|
39
|
-
MA==
|
36
|
+
version: '0'
|
40
37
|
none: false
|
41
38
|
requirement: !ruby/object:Gem::Requirement
|
42
39
|
requirements:
|
43
|
-
- -
|
40
|
+
- - '>='
|
44
41
|
- !ruby/object:Gem::Version
|
45
|
-
version:
|
46
|
-
MA==
|
42
|
+
version: '0'
|
47
43
|
none: false
|
48
44
|
prerelease: false
|
49
45
|
type: :development
|
@@ -54,7 +50,7 @@ executables: []
|
|
54
50
|
extensions: []
|
55
51
|
extra_rdoc_files: []
|
56
52
|
files:
|
57
|
-
-
|
53
|
+
- .gitignore
|
58
54
|
- CHANGELOG.md
|
59
55
|
- Gemfile
|
60
56
|
- LICENSE.txt
|
@@ -96,17 +92,15 @@ require_paths:
|
|
96
92
|
- lib
|
97
93
|
required_ruby_version: !ruby/object:Gem::Requirement
|
98
94
|
requirements:
|
99
|
-
- -
|
95
|
+
- - '>='
|
100
96
|
- !ruby/object:Gem::Version
|
101
|
-
version:
|
102
|
-
MA==
|
97
|
+
version: '0'
|
103
98
|
none: false
|
104
99
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
105
100
|
requirements:
|
106
|
-
- -
|
101
|
+
- - '>='
|
107
102
|
- !ruby/object:Gem::Version
|
108
|
-
version:
|
109
|
-
MA==
|
103
|
+
version: '0'
|
110
104
|
none: false
|
111
105
|
requirements: []
|
112
106
|
rubyforge_project:
|