@@ -1474,7 +1474,7 @@ QUnit.test( "pseudo - :target and :root", function( assert ) {
1474
1474
} ) ;
1475
1475
1476
1476
QUnit . test ( "pseudo - :lang" , function ( assert ) {
1477
- assert . expect ( QUnit . jQuerySelectors ? 105 : 55 ) ;
1477
+ assert . expect ( QUnit . jQuerySelectors ? 104 : 54 ) ;
1478
1478
1479
1479
var docElem = document . documentElement ,
1480
1480
docXmlLang = docElem . getAttribute ( "xml:lang" ) ,
@@ -1547,8 +1547,18 @@ QUnit.test( "pseudo - :lang", function( assert ) {
1547
1547
anchor . parentNode . lang = "ara" ;
1548
1548
anchor . lang = "ara\\b" ;
1549
1549
assert . deepEqual ( jQuery ( ":lang(ara\\b)" , foo ) . get ( ) , [ ] , ":lang respects backslashes" ) ;
1550
- assert . deepEqual ( jQuery ( ":lang(ara\\\\b)" , foo ) . get ( ) , [ anchor ] ,
1551
- ":lang respects escaped backslashes" ) ;
1550
+
1551
+ // Support: Firefox 114+
1552
+ // Firefox 114+ no longer match on backslashes in `:lang()`, even when escaped.
1553
+ // It is an intentional change as `:lang()` parameters are supposed to be valid
1554
+ // BCP 47 strings. Therefore, we won't attempt to patch it.
1555
+ // We'll keep this test here until other browsers match the behavior.
1556
+ // See https://bugzilla.mozilla.org/show_bug.cgi?id=1839747#c1
1557
+ // See https://github.com/w3c/csswg-drafts/issues/8720#issuecomment-1509242961
1558
+ //
1559
+ // assert.deepEqual( jQuery( ":lang(ara\\\\b)", foo ).get(), [ anchor ],
1560
+ // ":lang respects escaped backslashes" );
1561
+
1552
1562
assert . throws ( function ( ) {
1553
1563
jQuery ( "#qunit-fixture:lang(c++)" ) ;
1554
1564
} , ":lang value must be a valid identifier" ) ;
0 commit comments