@@ -1525,7 +1525,7 @@ QUnit.test( "pseudo - :target and :root", function( assert ) {
1525
1525
} ) ;
1526
1526
1527
1527
QUnit . test ( "pseudo - :lang" , function ( assert ) {
1528
- assert . expect ( QUnit . jQuerySelectors ? 105 : 55 ) ;
1528
+ assert . expect ( QUnit . jQuerySelectors ? 104 : 54 ) ;
1529
1529
1530
1530
var docElem = document . documentElement ,
1531
1531
docXmlLang = docElem . getAttribute ( "xml:lang" ) ,
@@ -1598,8 +1598,18 @@ QUnit.test( "pseudo - :lang", function( assert ) {
1598
1598
anchor . parentNode . lang = "ara" ;
1599
1599
anchor . lang = "ara\\b" ;
1600
1600
assert . deepEqual ( jQuery . find ( ":lang(ara\\b)" , foo ) , [ ] , ":lang respects backslashes" ) ;
1601
- assert . deepEqual ( jQuery . find ( ":lang(ara\\\\b)" , foo ) , [ anchor ] ,
1602
- ":lang respects escaped backslashes" ) ;
1601
+
1602
+ // Support: Firefox 114+
1603
+ // Firefox 114+ no longer match on backslashes in `:lang()`, even when escaped.
1604
+ // It is an intentional change as `:lang()` parameters are supposed to be valid
1605
+ // BCP 47 strings. Therefore, we won't attempt to patch it.
1606
+ // We'll keep this test here until other browsers match the behavior.
1607
+ // See https://bugzilla.mozilla.org/show_bug.cgi?id=1839747#c1
1608
+ // See https://github.com/w3c/csswg-drafts/issues/8720#issuecomment-1509242961
1609
+ //
1610
+ // assert.deepEqual( jQuery.find( ":lang(ara\\\\b)", foo ), [ anchor ],
1611
+ // ":lang respects escaped backslashes" );
1612
+
1603
1613
assert . throws ( function ( ) {
1604
1614
jQuery . find ( "#qunit-fixture:lang(c++)" ) ;
1605
1615
} , ":lang value must be a valid identifier" ) ;
0 commit comments