author Cosmin Sabou <>
Thu, 08 Dec 2022 02:27:45 +0200
changeset 645062 58f36d1b73c53785b92ce1c96598826ce536099c
parent 554551 994ae8e4833c90447d91f0e26a718573cff5a514
permissions -rw-r--r--
Backed out changeset 911f05c487a6 (bug 1800907) for causing assertions on 266445-1.html. CLOSED TREE

# -*- coding: UTF-8 -*-

import WebIDL

def WebIDLTest(parser, harness):
        interface TestUSVString {
          attribute USVString svs;

    results = parser.finish()

    harness.check(len(results), 1, "Should be one production")
    harness.ok(isinstance(results[0], WebIDL.IDLInterface), "Should be an IDLInterface")
    iface = results[0]
        iface.identifier.QName(), "::TestUSVString", "Interface has the right QName"
    harness.check(, "TestUSVString", "Interface has the right name"
    harness.check(iface.parent, None, "Interface has no parent")

    members = iface.members
    harness.check(len(members), 1, "Should be one member")

    attr = members[0]
    harness.ok(isinstance(attr, WebIDL.IDLAttribute), "Should be an IDLAttribute")
        attr.identifier.QName(), "::TestUSVString::svs", "Attr has correct QName"
    harness.check(, "svs", "Attr has correct name")
    harness.check(str(attr.type), "USVString", "Attr type is the correct name")
    harness.ok(attr.type.isUSVString(), "Should be USVString type")
    harness.ok(attr.type.isString(), "Should be String collective type")
    harness.ok(not attr.type.isDOMString(), "Should be not be DOMString type")