rsql 0.2.6 → 0.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/bin/rsql +81 -57
- metadata +6 -16
- data/LICENSE +0 -19
- data/example.rsqlrc +0 -291
- data/extra/mysql-client-5.1.59-1.tgz +0 -0
- data/lib/rsql.rb +0 -10
- data/lib/rsql/commands.rb +0 -243
- data/lib/rsql/eval_context.rb +0 -690
- data/lib/rsql/mysql_results.rb +0 -410
- data/test/test_commands.rb +0 -85
- data/test/test_eval_context.rb +0 -179
- data/test/test_mysql_results.rb +0 -130
    
        data/test/test_eval_context.rb
    DELETED
    
    | @@ -1,179 +0,0 @@ | |
| 1 | 
            -
            #!/usr/bin/env ruby
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            require 'test/unit'
         | 
| 4 | 
            -
            require 'tempfile'
         | 
| 5 | 
            -
             | 
| 6 | 
            -
            begin
         | 
| 7 | 
            -
                require 'rubygems'
         | 
| 8 | 
            -
            rescue LoadError
         | 
| 9 | 
            -
            end
         | 
| 10 | 
            -
            require 'mocha'
         | 
| 11 | 
            -
             | 
| 12 | 
            -
            $: << File.expand_path(File.join(File.dirname(__FILE__),'..','lib')) << File.dirname(__FILE__)
         | 
| 13 | 
            -
            require 'rsql/mysql_results.rb'
         | 
| 14 | 
            -
            require 'rsql/eval_context.rb'
         | 
| 15 | 
            -
             | 
| 16 | 
            -
            class TestEvalContext < Test::Unit::TestCase
         | 
| 17 | 
            -
             | 
| 18 | 
            -
                include RSQL
         | 
| 19 | 
            -
             | 
| 20 | 
            -
                def setup
         | 
| 21 | 
            -
                    @conn = mock('Mysql')
         | 
| 22 | 
            -
                    @conn.expects(:list_dbs).returns([])
         | 
| 23 | 
            -
                    @conn.expects(:query).with(instance_of(String)).returns(nil)
         | 
| 24 | 
            -
                    @conn.expects(:affected_rows).returns(0)
         | 
| 25 | 
            -
                    MySQLResults.conn = @conn
         | 
| 26 | 
            -
                    @ctx = EvalContext.new
         | 
| 27 | 
            -
                    @ctx.load(File.join(File.dirname(__FILE__),'..','example.rsqlrc'))
         | 
| 28 | 
            -
                end
         | 
| 29 | 
            -
             | 
| 30 | 
            -
                def test_reload
         | 
| 31 | 
            -
                    orig = $stdout
         | 
| 32 | 
            -
                    $stdout = out = StringIO.new
         | 
| 33 | 
            -
                    @conn.expects(:query).with(instance_of(String)).returns(nil)
         | 
| 34 | 
            -
                    @conn.expects(:affected_rows).returns(0)
         | 
| 35 | 
            -
                    @ctx.safe_eval('reload', nil, out)
         | 
| 36 | 
            -
                    assert_match(/loaded: .+?example.rsqlrc/, out.string)
         | 
| 37 | 
            -
                ensure
         | 
| 38 | 
            -
                    $stdout = orig
         | 
| 39 | 
            -
                end
         | 
| 40 | 
            -
             | 
| 41 | 
            -
                def test_eval
         | 
| 42 | 
            -
                    out = StringIO.new
         | 
| 43 | 
            -
             | 
| 44 | 
            -
                    # test a simple string registration
         | 
| 45 | 
            -
                    val = @ctx.safe_eval('cleanup_example', nil, out)
         | 
| 46 | 
            -
                    assert_equal('DROP TEMPORARY TABLE IF EXISTS rsql_example;', val)
         | 
| 47 | 
            -
                    assert_equal(true, out.string.empty?)
         | 
| 48 | 
            -
             | 
| 49 | 
            -
                    # test a block registration
         | 
| 50 | 
            -
                    val = @ctx.safe_eval('fill_table', nil, out)
         | 
| 51 | 
            -
                    assert_match(/(INSERT IGNORE INTO .+?){10}/, val)
         | 
| 52 | 
            -
                    assert_equal(true, out.string.empty?)
         | 
| 53 | 
            -
             | 
| 54 | 
            -
                    # test results handling and output redirection
         | 
| 55 | 
            -
                    res = mock
         | 
| 56 | 
            -
                    res.expects(:each_hash).yields({'value' => '2352'})
         | 
| 57 | 
            -
                    val = @ctx.safe_eval('to_report', res, out)
         | 
| 58 | 
            -
                    assert_equal(nil, val)
         | 
| 59 | 
            -
                    assert_equal("There are 1 small values and 0 big values.", out.string.chomp)
         | 
| 60 | 
            -
                end
         | 
| 61 | 
            -
             | 
| 62 | 
            -
                def test_list
         | 
| 63 | 
            -
                    out = StringIO.new
         | 
| 64 | 
            -
                    val = @ctx.safe_eval('list', nil, out)
         | 
| 65 | 
            -
                    assert_match(/usage\s+description/, out.string)
         | 
| 66 | 
            -
                end
         | 
| 67 | 
            -
             | 
| 68 | 
            -
                def test_params
         | 
| 69 | 
            -
                    val = @ctx.safe_eval('params("ft", @registrations[:fill_table].block)', nil, nil)
         | 
| 70 | 
            -
                    assert_equal('', val)
         | 
| 71 | 
            -
                    val = @ctx.safe_eval('params("sv", @registrations[:save_values].block)', nil, nil)
         | 
| 72 | 
            -
                    assert_equal('(fn)', val)
         | 
| 73 | 
            -
                end
         | 
| 74 | 
            -
             | 
| 75 | 
            -
                def test_desc
         | 
| 76 | 
            -
                    out = StringIO.new
         | 
| 77 | 
            -
                    err = StringIO.new
         | 
| 78 | 
            -
                    orig_err = $stderr
         | 
| 79 | 
            -
             | 
| 80 | 
            -
                    $stderr = err
         | 
| 81 | 
            -
                    val = @ctx.safe_eval('desc max_rows', nil, out)
         | 
| 82 | 
            -
                    $sterr = orig_err
         | 
| 83 | 
            -
                    assert_equal('', out.string)
         | 
| 84 | 
            -
                    assert_equal('refusing to describe EvalContext#max_rows',
         | 
| 85 | 
            -
                                 err.string.chomp)
         | 
| 86 | 
            -
             | 
| 87 | 
            -
                    err.string = ''
         | 
| 88 | 
            -
                    $stderr = err
         | 
| 89 | 
            -
                    val = @ctx.safe_eval('desc :sldkfjas', nil, out)
         | 
| 90 | 
            -
                    $sterr = orig_err
         | 
| 91 | 
            -
                    assert_equal('', out.string)
         | 
| 92 | 
            -
                    assert_equal('nothing registered as sldkfjas', err.string.chomp)
         | 
| 93 | 
            -
             | 
| 94 | 
            -
                    err.string = ''
         | 
| 95 | 
            -
                    $stderr = err
         | 
| 96 | 
            -
                    val = @ctx.safe_eval('desc :version', nil, out)
         | 
| 97 | 
            -
                    $sterr = orig_err
         | 
| 98 | 
            -
                    assert_equal('', out.string)
         | 
| 99 | 
            -
                    assert_equal('refusing to describe the version method', err.string.chomp)
         | 
| 100 | 
            -
             | 
| 101 | 
            -
                    err.string = ''
         | 
| 102 | 
            -
                    out.string = ''
         | 
| 103 | 
            -
                    val = @ctx.safe_eval('desc :cleanup_example', nil, out)
         | 
| 104 | 
            -
                    assert_equal('', err.string)
         | 
| 105 | 
            -
                    assert_match(
         | 
| 106 | 
            -
                        /^\s*\[.+\/example.rsqlrc:\d+\]\s+DROP TEMPORARY TABLE IF EXISTS \#\{@rsql_table\}\s*$/,
         | 
| 107 | 
            -
                        out.string)
         | 
| 108 | 
            -
             | 
| 109 | 
            -
                    out.string = ''
         | 
| 110 | 
            -
                    val = @ctx.safe_eval('desc :to_report', nil, out)
         | 
| 111 | 
            -
                    lines = out.string.split($/).select{|l|l.any?}
         | 
| 112 | 
            -
                    assert_match(/^\[.+\/example.rsqlrc:\d+\]$/, lines[0])
         | 
| 113 | 
            -
                    assert_match(/^register .+ do$/, lines[1])
         | 
| 114 | 
            -
                    assert_match(/^\s+puts/, lines[-2])
         | 
| 115 | 
            -
                    assert_match(/^end$/, lines[-1])
         | 
| 116 | 
            -
                    assert_equal(13, lines.size)
         | 
| 117 | 
            -
                end
         | 
| 118 | 
            -
             | 
| 119 | 
            -
                def test_complete
         | 
| 120 | 
            -
                    out = @ctx.complete('')
         | 
| 121 | 
            -
                    assert_equal(19, out.size, out.inspect)
         | 
| 122 | 
            -
                    assert_equal(['version'], @ctx.complete('v'))
         | 
| 123 | 
            -
                    assert_equal(['.version'], @ctx.complete('.v'))
         | 
| 124 | 
            -
                end
         | 
| 125 | 
            -
             | 
| 126 | 
            -
                def test_bang_eval
         | 
| 127 | 
            -
                    @ctx.bangs = {'time' => :relative_time}
         | 
| 128 | 
            -
                    t = (Time.now - 2532435).to_s
         | 
| 129 | 
            -
                    assert_equal(t, @ctx.bang_eval('do no harm', t))
         | 
| 130 | 
            -
                    assert_equal(' 29 days ago', @ctx.bang_eval('time', t))
         | 
| 131 | 
            -
                end
         | 
| 132 | 
            -
             | 
| 133 | 
            -
                def test_humanize
         | 
| 134 | 
            -
                    out = StringIO.new
         | 
| 135 | 
            -
                    assert_equal('   9.16 GB',
         | 
| 136 | 
            -
                                 @ctx.safe_eval('humanize_bytes(9832742324)', nil, out))
         | 
| 137 | 
            -
                    assert_equal(9835475108,
         | 
| 138 | 
            -
                                 @ctx.safe_eval('dehumanize_bytes("   9.16 GB")', nil, out))
         | 
| 139 | 
            -
                    assert_equal(' 20.9%',
         | 
| 140 | 
            -
                                 @ctx.safe_eval('humanize_percentage(0.209384)', nil, out))
         | 
| 141 | 
            -
                    assert(out.string.empty?)
         | 
| 142 | 
            -
                end
         | 
| 143 | 
            -
             | 
| 144 | 
            -
                def test_hex
         | 
| 145 | 
            -
                    bin = ''
         | 
| 146 | 
            -
                    100.times{|i| bin << i}
         | 
| 147 | 
            -
                    hex = @ctx.to_hexstr(bin)
         | 
| 148 | 
            -
                    assert_equal('0x000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f' <<
         | 
| 149 | 
            -
                                 '... (68 bytes hidden)', hex)
         | 
| 150 | 
            -
             | 
| 151 | 
            -
                    out = StringIO.new
         | 
| 152 | 
            -
                    assert_equal('0x1234', @ctx.safe_eval('hexify("1234")', nil, out))
         | 
| 153 | 
            -
                    assert_equal('0x1234', @ctx.safe_eval('hexify("0x1234")', nil, out))
         | 
| 154 | 
            -
                    assert_equal('0x1234', @ctx.safe_eval('hexify(0x1234)', nil, out))
         | 
| 155 | 
            -
                    assert(out.string.empty?)
         | 
| 156 | 
            -
                end
         | 
| 157 | 
            -
             | 
| 158 | 
            -
                def test_safe_save
         | 
| 159 | 
            -
                    out = StringIO.new
         | 
| 160 | 
            -
                    @ctx.safe_eval('@mystuff = {:one => 1, :two => 2}', nil, out)
         | 
| 161 | 
            -
                    tf = Tempfile.new('mystuff')
         | 
| 162 | 
            -
                    @ctx.safe_eval("safe_save(@mystuff, '#{tf.path}')", nil, out)
         | 
| 163 | 
            -
                    tf = tf.path + '.yml'
         | 
| 164 | 
            -
                    assert_equal("Saved: #{tf}", out.string.chomp)
         | 
| 165 | 
            -
                    assert_equal({:one => 1, :two => 2}, YAML.load_file(tf))
         | 
| 166 | 
            -
             | 
| 167 | 
            -
                    # now make sure it keeps one backup copy
         | 
| 168 | 
            -
                    out = StringIO.new
         | 
| 169 | 
            -
                    @ctx.safe_eval('@mystuff = {:one => 1}', nil, out)
         | 
| 170 | 
            -
                    @ctx.safe_eval("safe_save(@mystuff, '#{tf}')", nil, out)
         | 
| 171 | 
            -
                    assert_equal("Saved: #{tf}", out.string.chomp)
         | 
| 172 | 
            -
                    assert_equal({:one => 1}, YAML.load_file(tf))
         | 
| 173 | 
            -
                    assert_equal({:one => 1, :two => 2}, YAML.load_file(tf+'~'))
         | 
| 174 | 
            -
                ensure
         | 
| 175 | 
            -
                    File.unlink(tf) if File.exists?(tf)
         | 
| 176 | 
            -
                    File.unlink(tf+'~') if File.exists?(tf+'~')
         | 
| 177 | 
            -
                end
         | 
| 178 | 
            -
             | 
| 179 | 
            -
            end # class TestEvalContext
         | 
    
        data/test/test_mysql_results.rb
    DELETED
    
    | @@ -1,130 +0,0 @@ | |
| 1 | 
            -
            #!/usr/bin/env ruby
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            require 'test/unit'
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            begin
         | 
| 6 | 
            -
                require 'rubygems'
         | 
| 7 | 
            -
            rescue LoadError
         | 
| 8 | 
            -
            end
         | 
| 9 | 
            -
            require 'mocha'
         | 
| 10 | 
            -
             | 
| 11 | 
            -
            $: << File.expand_path(File.join(File.dirname(__FILE__),'..','lib')) << File.dirname(__FILE__)
         | 
| 12 | 
            -
            require 'rsql/mysql_results.rb'
         | 
| 13 | 
            -
             | 
| 14 | 
            -
            class TestMySQLResults < Test::Unit::TestCase
         | 
| 15 | 
            -
             | 
| 16 | 
            -
                include RSQL
         | 
| 17 | 
            -
             | 
| 18 | 
            -
                def setup
         | 
| 19 | 
            -
                    MySQLResults.conn = nil
         | 
| 20 | 
            -
                    MySQLResults.database_name = nil
         | 
| 21 | 
            -
                    MySQLResults.reset_cache
         | 
| 22 | 
            -
                end
         | 
| 23 | 
            -
             | 
| 24 | 
            -
                def test_databases
         | 
| 25 | 
            -
                    assert_equal([], MySQLResults.databases)
         | 
| 26 | 
            -
                    conn = mock('Mysql')
         | 
| 27 | 
            -
                    conn.expects(:list_dbs).returns(['accounts'])
         | 
| 28 | 
            -
                    conn.expects(:select_db)
         | 
| 29 | 
            -
                    conn.expects(:list_tables).returns([])
         | 
| 30 | 
            -
                    MySQLResults.conn = conn
         | 
| 31 | 
            -
                    assert_equal(['accounts'], MySQLResults.databases)
         | 
| 32 | 
            -
                end
         | 
| 33 | 
            -
             | 
| 34 | 
            -
                def test_tables
         | 
| 35 | 
            -
                    assert_equal([], MySQLResults.tables)
         | 
| 36 | 
            -
                    MySQLResults.reset_cache
         | 
| 37 | 
            -
             | 
| 38 | 
            -
                    conn = mock('Mysql')
         | 
| 39 | 
            -
                    conn.expects(:list_dbs).returns(['accounts'])
         | 
| 40 | 
            -
                    conn.expects(:select_db)
         | 
| 41 | 
            -
                    conn.expects(:list_tables).returns(['users','groups'])
         | 
| 42 | 
            -
                    MySQLResults.conn = conn
         | 
| 43 | 
            -
             | 
| 44 | 
            -
                    assert_equal([], MySQLResults.tables)
         | 
| 45 | 
            -
                    MySQLResults.database_name = 'accounts'
         | 
| 46 | 
            -
                    assert_equal(['groups','users'], MySQLResults.tables)
         | 
| 47 | 
            -
                    assert_equal(['groups','users'], MySQLResults.tables('accounts'))
         | 
| 48 | 
            -
                end
         | 
| 49 | 
            -
             | 
| 50 | 
            -
                def test_complete
         | 
| 51 | 
            -
                    assert_equal([], MySQLResults.complete(nil))
         | 
| 52 | 
            -
             | 
| 53 | 
            -
                    conn = mock('Mysql')
         | 
| 54 | 
            -
                    conn.expects(:list_dbs).returns(['Accounts','Devices','Locations'])
         | 
| 55 | 
            -
                    conn.expects(:select_db).times(3)
         | 
| 56 | 
            -
                    tbls = sequence(:tbls)
         | 
| 57 | 
            -
                    conn.expects(:list_tables).in_sequence(tbls).returns(['Prefs','Names'])
         | 
| 58 | 
            -
                    conn.expects(:list_tables).in_sequence(tbls).returns(['IPs'])
         | 
| 59 | 
            -
                    conn.expects(:list_tables).in_sequence(tbls).returns(['Street','City','State'])
         | 
| 60 | 
            -
                    MySQLResults.conn = conn
         | 
| 61 | 
            -
             | 
| 62 | 
            -
                    assert_equal(['Accounts','Devices','Locations'], MySQLResults.complete(''))
         | 
| 63 | 
            -
                    assert_equal(['Accounts'], MySQLResults.complete('a'))
         | 
| 64 | 
            -
             | 
| 65 | 
            -
                    MySQLResults.database_name = 'Accounts'
         | 
| 66 | 
            -
                    assert_equal(['Devices','Locations','Names','Prefs'], MySQLResults.complete(''))
         | 
| 67 | 
            -
                    assert_equal(['Names'], MySQLResults.complete('n'))
         | 
| 68 | 
            -
             | 
| 69 | 
            -
                    assert_equal(['Accounts.Names','Accounts.Prefs'], MySQLResults.complete('accounts.'))
         | 
| 70 | 
            -
                end
         | 
| 71 | 
            -
             | 
| 72 | 
            -
                def test_query
         | 
| 73 | 
            -
                    f1 = mock('f1')
         | 
| 74 | 
            -
                    f1.expects(:name).returns('c1').times(12)
         | 
| 75 | 
            -
                    f1.expects(:type).returns(1).times(2)
         | 
| 76 | 
            -
                    f2 = mock('f2')
         | 
| 77 | 
            -
                    f2.expects(:name).returns('c2').times(11)
         | 
| 78 | 
            -
                    f2.expects(:type).returns(1).times(2)
         | 
| 79 | 
            -
             | 
| 80 | 
            -
                    res = mock('results')
         | 
| 81 | 
            -
                    res.expects(:num_rows).returns(2).times(2)
         | 
| 82 | 
            -
                    res.expects(:fetch_fields).returns([f1,f2])
         | 
| 83 | 
            -
             | 
| 84 | 
            -
                    rows = sequence(:rows)
         | 
| 85 | 
            -
                    res.expects(:fetch_row).in_sequence(rows).returns(['v1.1','v1.2'])
         | 
| 86 | 
            -
                    res.expects(:fetch_row).in_sequence(rows).returns(['v2.1','v2.2'])
         | 
| 87 | 
            -
                    res.expects(:fetch_row).in_sequence(rows).returns(nil)
         | 
| 88 | 
            -
             | 
| 89 | 
            -
                    conn = mock('Mysql')
         | 
| 90 | 
            -
                    conn.expects(:list_dbs).returns([])
         | 
| 91 | 
            -
                    conn.expects(:query).with(instance_of(String)).returns(res)
         | 
| 92 | 
            -
                    conn.expects(:affected_rows).returns(1)
         | 
| 93 | 
            -
                    MySQLResults.conn = conn
         | 
| 94 | 
            -
             | 
| 95 | 
            -
                    bangs = mock('bangs')
         | 
| 96 | 
            -
                    bangs.expects(:bang_eval).with(instance_of(String),instance_of(String)).
         | 
| 97 | 
            -
                        returns('val').times(4)
         | 
| 98 | 
            -
             | 
| 99 | 
            -
                    mres = MySQLResults.query('ignored', bangs)
         | 
| 100 | 
            -
                    assert_equal('ignored', mres.sql)
         | 
| 101 | 
            -
                    assert_equal(true, mres.any?)
         | 
| 102 | 
            -
                    assert_equal(false, mres.empty?)
         | 
| 103 | 
            -
                    assert_equal(2, mres.num_rows)
         | 
| 104 | 
            -
                    assert_equal({"c1"=>"val", "c2"=>"val"}, mres[0])
         | 
| 105 | 
            -
                    assert_equal({"c1"=>"val", "c2"=>"val"}, mres[1])
         | 
| 106 | 
            -
                    assert_equal(nil, mres[2])
         | 
| 107 | 
            -
             | 
| 108 | 
            -
                    cnt = 0
         | 
| 109 | 
            -
                    mres.each_hash do |row|
         | 
| 110 | 
            -
                        cnt += 1
         | 
| 111 | 
            -
                        assert_equal({"c1"=>"val", "c2"=>"val"}, row)
         | 
| 112 | 
            -
                    end
         | 
| 113 | 
            -
                    assert_equal(2, cnt)
         | 
| 114 | 
            -
             | 
| 115 | 
            -
                    dout = StringIO.new
         | 
| 116 | 
            -
                    mres.display_by_column(dout)
         | 
| 117 | 
            -
                    assert_match(/^c1c2--------valvalvalval--------2rowsinset/,
         | 
| 118 | 
            -
                                 dout.string.gsub(/\s+/,''))
         | 
| 119 | 
            -
             | 
| 120 | 
            -
                    dout = StringIO.new
         | 
| 121 | 
            -
                    mres.display_by_batch(dout)
         | 
| 122 | 
            -
                    assert_equal('valvalvalval', dout.string.gsub(/\s+/,''))
         | 
| 123 | 
            -
             | 
| 124 | 
            -
                    dout = StringIO.new
         | 
| 125 | 
            -
                    mres.display_by_line(dout)
         | 
| 126 | 
            -
                    assert_match(/^\*+1.row\*+c1:valc2:val\*+2.row\*+c1:valc2:val2rowsinset/,
         | 
| 127 | 
            -
                                 dout.string.gsub(/\s+/,''))
         | 
| 128 | 
            -
                end
         | 
| 129 | 
            -
             | 
| 130 | 
            -
            end # class TestMySQLResults
         |