getLang()->ucfirst( $input ); } elseif ( $func == 'lcfirst' ) { $res = $this->getLang()->lcfirst( $input ); } else { throw new MWException( __METHOD__ . " given an invalid function name '$func'" ); } $msg = "Converting $inputCase case '$input' with $func should give '$expected'"; $this->assertEquals( $expected, $res, $msg ); } public static function provideDottedAndDotlessI() { return [ # function, input, input case, expected # Case changed: [ 'ucfirst', 'ı', 'lower', 'I' ], [ 'ucfirst', 'i', 'lower', 'İ' ], [ 'lcfirst', 'I', 'upper', 'ı' ], [ 'lcfirst', 'İ', 'upper', 'i' ], # Already using the correct case [ 'ucfirst', 'I', 'upper', 'I' ], [ 'ucfirst', 'İ', 'upper', 'İ' ], [ 'lcfirst', 'ı', 'lower', 'ı' ], [ 'lcfirst', 'i', 'lower', 'i' ], # A real example taken from T30040 using # https://tr.wikipedia.org/wiki/%C4%B0Phone [ 'lcfirst', 'iPhone', 'lower', 'iPhone' ], # next case is valid in Turkish but are different words if we # consider IPhone is English! [ 'lcfirst', 'IPhone', 'upper', 'ıPhone' ], ]; } }