File: test_mixed_unicode_escapes.rb

package info (click to toggle)
ruby3.4 3.4.5-1~exp1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 154,784 kB
  • sloc: ruby: 1,259,653; ansic: 829,955; yacc: 28,233; pascal: 7,359; sh: 3,864; python: 1,799; cpp: 1,158; asm: 808; makefile: 801; javascript: 414; lisp: 109; perl: 62; awk: 36; sed: 4; xml: 4
file content (30 lines) | stat: -rw-r--r-- 1,180 bytes parent folder | download
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(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(/#{"\u1234"}#{""}/)}
    assert_raise(Encoding::CompatibilityError) { eval %q("\u{1234}#{nil}")}
    assert_raise(Encoding::CompatibilityError) { eval %q("#{nil}\u1234")}
  end
end