Sha256: fe7262f9453b8da25e45def06d1b3f05f7bbb149a08b051f9ff1a488332b0328
Contents?: true
Size: 1.68 KB
Versions: 8
Compression:
Stored size: 1.68 KB
Contents
require 'test_helper' class SerializableTest < ActiveSupport::TestCase setup do @user = create_user end test 'should not include unsafe keys on XML' do assert_match /email/, @user.to_xml assert_no_match /confirmation-token/, @user.to_xml end test 'should not include unsafe keys on XML even if a new except is provided' do assert_no_match /email/, @user.to_xml(:except => :email) assert_no_match /confirmation-token/, @user.to_xml(:except => :email) end test 'should include unsafe keys on XML if a force_except is provided' do assert_no_match /<email/, @user.to_xml(:force_except => :email) assert_match /confirmation-token/, @user.to_xml(:force_except => :email) end test 'should not include unsafe keys on JSON' do keys = from_json().keys.select{ |key| !key.include?("id") } assert_equal %w(created_at email facebook_token updated_at username), keys.sort end test 'should not include unsafe keys on JSON even if a new except is provided' do assert_no_key "email", from_json(:except => :email) assert_no_key "confirmation_token", from_json(:except => :email) end test 'should include unsafe keys on JSON if a force_except is provided' do assert_no_key "email", from_json(:force_except => :email) assert_key "confirmation_token", from_json(:force_except => :email) end def assert_key(key, subject) assert subject.key?(key), "Expected #{subject.inspect} to have key #{key.inspect}" end def assert_no_key(key, subject) assert !subject.key?(key), "Expected #{subject.inspect} to not have key #{key.inspect}" end def from_json(options=nil) ActiveSupport::JSON.decode(@user.to_json(options))["user"] end end
Version data entries
8 entries across 8 versions & 4 rubygems