- 
                Notifications
    You must be signed in to change notification settings 
- Fork 27.3k
fix($injector): fix class detection RegExp #14533
fix($injector): fix class detection RegExp #14533
Conversation
        
          
                src/auto/injector.js
              
                Outdated
          
        
      | var result = func.$$ngIsClass; | ||
| if (!isBoolean(result)) { | ||
| // Support: Edge 12-13 only | ||
| // Workaround for MS Edge. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This line seems kind of moot now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed
03b9807    to
    e1b7b89      
    Compare
  
    | There seem to be some failures on Safari. I'll have to investigate further 😒 | 
| So, basically, we can't detect classes in Safari 9 😞 What should we do about it ? Skip the tests on Safari ? | 
| 
 Yeah, I think so. Classes are not supported everywhere yet, it's natural some browsers might have buggy support for some time; people relying on classes in Angular will need to restrict support to well-behaving environments. Note that Safari Technology Preview stringifies classes correctly so Safari 10 (coming out in ~6 months if the past is any indication) will be fine. | 
| Yeah, I meant what should we do about the tests (which are failing on CI - as expected). | 
e1b7b89    to
    8a647ef      
    Compare
  
    | @gkalpak Why just to Chrome? What about Firefox? | 
| Firefox (at least up to v46) does not stringify classes in a way that allows class detection 😞  | 
| Yeah, they have an open bug for it, it's not fixed even on Nightly (v49)
yet: https://bugzilla.mozilla.org/show_bug.cgi?id=1216630
 | 
| expect(instance.aVal()).toEqual('a-value'); | ||
| }); | ||
|  | ||
| if (/chrome/.test(navigator.userAgent)) { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why wrap this in a browser sniff for Chrome only? Since this test doesn't look browser specific and is just more about the injector doing the right thing, I think it'd make more sense to feature detect the support for ES6 classes
  var supportsClasses = (function() {
    try {
      var klass = eval("class C {}");
      // Workaround the buggy implementation of `toString` in Firefox
      // https://bugzilla.mozilla.org/show_bug.cgi?id=1216630
      return klass.toString().indexOf('class') !== -1;
    } catch (err) {
      return false;
    }
  }());
  if (supportsClasses) { ... }There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The situation in tests is a little different; in jQuery e.g. we don't sniff in source but if a specific bug exists in a specific browser & version we do sniff in tests. This is not only because it's simpler to do but also to rule out the possibility that a broken support check will make the tests be skipped - we do want to verify that in these specific browsers they're being run.
I agree with you here, though as we're talking about a bleeding-edge feature that browsers are only implementing now and more & more of them will have it in a working state. That's different.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I generally agree, but there is not much we can do here unfortunately. There is more context in the comments (e.g. starting at #14533 (comment)).
Mentioned in #14531 (comment). Closes #14533
What kind of change does this PR introduce? (Bug fix, feature, docs update, ...)
Bug fix
What is the current behavior? (You can also link to an open issue here)
ES6 classes are not properly detected unless
classis followed by a whitespace character.What is the new behavior (if this is a feature change)?
ES6 classes are properly detected, even if class is not followed by a whitespace character.
E.g.
class{}orclass/* ... */ {}.Does this PR introduce a breaking change?
No
Please check if the PR fulfills these requirements
Docs have been added / updated (for bug fixes / features)Other information:
Mentioned in #14531 (comment).