Sha256: cf79f55533913cfeef3f0aebc394d68ab0030481d3b7bf9e185999fe3ae61ebf

Contents?: true

Size: 1.4 KB

Versions: 9

Compression:

Stored size: 1.4 KB

Contents

require_relative 'helper'

describe 'Adapter' do
  supported_by Swift::Adapter::Postgres, Swift::Adapter::Mysql, Swift::Adapter::Sqlite3 do
    describe 'character encoding' do
      before do
        Swift.db do |db|
          db.execute %q{drop table if exists users}
          db.execute %q{create table users(name text)}

          # Mysql on debian at least doesn't default to utf8.
          if db.kind_of? Swift::Adapter::Mysql
            db.execute %q{alter table users default character set utf8}
            db.execute %q{alter table users change name name text charset utf8}
          end
        end
      end

      it 'should store and retrieve utf8 characters' do
        Swift.db do |db|
          name = "King of \u2665s"
          db.prepare("insert into users (name) values(?)").execute(name)
          value = db.prepare("select * from users limit 1").execute.first[:name]
          assert_equal Encoding::UTF_8, value.encoding
          assert_equal name, value
        end
      end

      it 'should store and retrieve non ascii' do
        Swift.db do |db|
          name = "\xA1\xB8".force_encoding("euc-jp")
          db.prepare("insert into users (name) values(?)").execute(name)
          value = db.prepare("select * from users limit 1").execute.first[:name]
          assert_equal Encoding::UTF_8, value.encoding
          assert_equal name.encode("utf-8"), value
        end
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
swift-1.2.3 test/test_encoding.rb
swift-1.2.2 test/test_encoding.rb
swift-1.2.1 test/test_encoding.rb
swift-1.2.0 test/test_encoding.rb
swift-1.1.0 test/test_encoding.rb
swift-1.0.3 test/test_encoding.rb
swift-1.0.2 test/test_encoding.rb
swift-1.0.1 test/test_encoding.rb
swift-1.0.0 test/test_encoding.rb