| // Copyright (c) 2015, the Dart project authors.  Please see the AUTHORS file | 
 | // for details. All rights reserved. Use of this source code is governed by a | 
 | // BSD-style license that can be found in the LICENSE file. | 
 |  | 
 | // Test that the proper one-shot interceptor is used for different | 
 | // combinations of named arguments. | 
 | import "package:expect/expect.dart"; | 
 |  | 
 | // Use dart:html to get interceptors into play. | 
 | import "dart:html"; | 
 |  | 
 | // [createFragment] has the same signature as in [Element]. | 
 | class Other { | 
 |   createFragment(html, {validator, treeSanitizer}) { | 
 |     int result = 0; | 
 |     result += validator == null ? 0 : 2; | 
 |     result += treeSanitizer == null ? 0 : 1; | 
 |     return result; | 
 |   } | 
 | } | 
 |  | 
 | @pragma('dart2js:noInline') | 
 | bool wontTell(bool x) => x; | 
 |  | 
 | // Ensure that we use the interceptor only once per context so that we | 
 | // actually get a one-shot interceptor. This is a little brittle... | 
 | @pragma('dart2js:noInline') | 
 | testA(thing) { | 
 |   Expect.equals(0, thing.createFragment(null)); | 
 | } | 
 |  | 
 | @pragma('dart2js:noInline') | 
 | testB(thing) { | 
 |   Expect.equals(2, thing.createFragment(null, validator: 1)); | 
 | } | 
 |  | 
 | @pragma('dart2js:noInline') | 
 | testC(thing) { | 
 |   Expect.equals(1, thing.createFragment(null, treeSanitizer: 1)); | 
 | } | 
 |  | 
 | @pragma('dart2js:noInline') | 
 | testD(thing) { | 
 |   Expect.equals(3, thing.createFragment(null, validator: 1, treeSanitizer: 1)); | 
 | } | 
 |  | 
 | main() { | 
 |   // Ensure we get interceptors into play. | 
 |   var thing = wontTell(true) ? new Other() : new DivElement(); | 
 |   testA(thing); | 
 |   testB(thing); | 
 |   testC(thing); | 
 |   testD(thing); | 
 | } |