Adding test coverage for 'OptionalChain'.PrivateIdentifier case (#2534)

This commit is contained in:
Caio Lima 2020-03-23 19:47:51 -03:00 committed by GitHub
parent 344612b592
commit db6f630e65
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 128 additions and 0 deletions

View File

@ -0,0 +1,40 @@
// Copyright (C) 2020 Caio Lima (Igalia SL). All rights reserved.
// This code is governed by the BSD license found in the LICENSE file.
/*---
desc: OptionalChain.PrivateIdentifier is a valid syntax
info: |
Updated Productions
OptionalChain[Yield, Await] :
`?.` `[` Expression[+In, ?Yield, ?Await] `]`
`?.` IdentifierName
`?.` Arguments[?Yield, ?Await]
`?.` TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `[` Expression[+In, ?Yield, ?Await] `]`
OptionalChain[?Yield, ?Await] `.` IdentifierName
OptionalChain[?Yield, ?Await] Arguments[?Yield, ?Await]
OptionalChain[?Yield, ?Await] TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `.` PrivateIdentifier
template: default
features: [class-fields-private, optional-chaining]
---*/
//- elements
#f = 'Test262';
method(o) {
return o?.c.#f;
}
//- assertions
let c = new C();
let o = {c: c};
assert.sameValue(c.method(o), 'Test262');
assert.sameValue(c.method(null), undefined);
assert.sameValue(c.method(undefined), undefined);
o = {c: new Object()};
assert.throws(TypeError, function() {
c.method(o);
}, 'accessed private field from an ordinary object');

View File

@ -0,0 +1,44 @@
// This file was procedurally generated from the following sources:
// - src/class-elements/private-field-after-optional-chain.case
// - src/class-elements/default/cls-expr.template
/*---
description: OptionalChain.PrivateIdentifier is a valid syntax (field definitions in a class expression)
esid: prod-FieldDefinition
features: [class-fields-private, optional-chaining, class]
flags: [generated]
info: |
Updated Productions
OptionalChain[Yield, Await] :
`?.` `[` Expression[+In, ?Yield, ?Await] `]`
`?.` IdentifierName
`?.` Arguments[?Yield, ?Await]
`?.` TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `[` Expression[+In, ?Yield, ?Await] `]`
OptionalChain[?Yield, ?Await] `.` IdentifierName
OptionalChain[?Yield, ?Await] Arguments[?Yield, ?Await]
OptionalChain[?Yield, ?Await] TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `.` PrivateIdentifier
---*/
var C = class {
#f = 'Test262';
method(o) {
return o?.c.#f;
}
}
let c = new C();
let o = {c: c};
assert.sameValue(c.method(o), 'Test262');
assert.sameValue(c.method(null), undefined);
assert.sameValue(c.method(undefined), undefined);
o = {c: new Object()};
assert.throws(TypeError, function() {
c.method(o);
}, 'accessed private field from an ordinary object');

View File

@ -0,0 +1,44 @@
// This file was procedurally generated from the following sources:
// - src/class-elements/private-field-after-optional-chain.case
// - src/class-elements/default/cls-decl.template
/*---
description: OptionalChain.PrivateIdentifier is a valid syntax (field definitions in a class declaration)
esid: prod-FieldDefinition
features: [class-fields-private, optional-chaining, class]
flags: [generated]
info: |
Updated Productions
OptionalChain[Yield, Await] :
`?.` `[` Expression[+In, ?Yield, ?Await] `]`
`?.` IdentifierName
`?.` Arguments[?Yield, ?Await]
`?.` TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `[` Expression[+In, ?Yield, ?Await] `]`
OptionalChain[?Yield, ?Await] `.` IdentifierName
OptionalChain[?Yield, ?Await] Arguments[?Yield, ?Await]
OptionalChain[?Yield, ?Await] TemplateLiteral[?Yield, ?Await, +Tagged]
OptionalChain[?Yield, ?Await] `.` PrivateIdentifier
---*/
class C {
#f = 'Test262';
method(o) {
return o?.c.#f;
}
}
let c = new C();
let o = {c: c};
assert.sameValue(c.method(o), 'Test262');
assert.sameValue(c.method(null), undefined);
assert.sameValue(c.method(undefined), undefined);
o = {c: new Object()};
assert.throws(TypeError, function() {
c.method(o);
}, 'accessed private field from an ordinary object');