blob: f0b4cc691f02c836e8c67d50e439d8bc87f20979 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
# -*- coding: cp932 -*-
# frozen_string_literal: false
# This test is in a different file than TestUnicodeEscapes
# So that we can have a different coding comment above
require 'test/unit'
class TestMixedUnicodeEscape < Test::Unit::TestCase
def test_basic
# Unicode escapes do work in an sjis encoded file, but only
# if they don't contain other multi-byte chars
assert_equal("A", "\u0041")
# 8-bit character escapes are okay.
assert_equal("B\xFF", "\u0042\xFF")
# sjis mb chars mixed with Unicode should not work
assert_raise(SyntaxError) { eval %q("\u1234")}
assert_raise(SyntaxError) { eval %q("\u{1234}")}
# also should not work for Regexp
assert_raise(SyntaxError) { eval %q(/#{"\u1234"}#{""}/)}
assert_raise(RegexpError) { eval %q(/\u{1234}#{nil}/)}
assert_raise(RegexpError) { eval %q(/#{nil}\u1234/)}
# String interpolation turns into an expression and we get
# a different kind of error, but we still can't mix these
assert_raise(Encoding::CompatibilityError) { eval %q("\u{1234}#{nil}")}
assert_raise(Encoding::CompatibilityError) { eval %q("#{nil}\u1234")}
end
end
|