Support offsets in prefix searching
[mediawiki.git] / tests / phpunit / includes / GlobalFunctions / wfBaseConvertTest.php
blob9d55e85c81e062f40ed67855ebedff6d1c68972e
1 <?php
2 /**
3 * @group GlobalFunctions
4 * @covers ::wfBaseConvert
5 */
6 class WfBaseConvertTest extends MediaWikiTestCase {
7 public static function provideSingleDigitConversions() {
8 return array(
9 // 2 3 5 8 10 16 36
10 array( '0', '0', '0', '0', '0', '0', '0' ),
11 array( '1', '1', '1', '1', '1', '1', '1' ),
12 array( '10', '2', '2', '2', '2', '2', '2' ),
13 array( '11', '10', '3', '3', '3', '3', '3' ),
14 array( '100', '11', '4', '4', '4', '4', '4' ),
15 array( '101', '12', '10', '5', '5', '5', '5' ),
16 array( '110', '20', '11', '6', '6', '6', '6' ),
17 array( '111', '21', '12', '7', '7', '7', '7' ),
18 array( '1000', '22', '13', '10', '8', '8', '8' ),
19 array( '1001', '100', '14', '11', '9', '9', '9' ),
20 array( '1010', '101', '20', '12', '10', 'a', 'a' ),
21 array( '1011', '102', '21', '13', '11', 'b', 'b' ),
22 array( '1100', '110', '22', '14', '12', 'c', 'c' ),
23 array( '1101', '111', '23', '15', '13', 'd', 'd' ),
24 array( '1110', '112', '24', '16', '14', 'e', 'e' ),
25 array( '1111', '120', '30', '17', '15', 'f', 'f' ),
26 array( '10000', '121', '31', '20', '16', '10', 'g' ),
27 array( '10001', '122', '32', '21', '17', '11', 'h' ),
28 array( '10010', '200', '33', '22', '18', '12', 'i' ),
29 array( '10011', '201', '34', '23', '19', '13', 'j' ),
30 array( '10100', '202', '40', '24', '20', '14', 'k' ),
31 array( '10101', '210', '41', '25', '21', '15', 'l' ),
32 array( '10110', '211', '42', '26', '22', '16', 'm' ),
33 array( '10111', '212', '43', '27', '23', '17', 'n' ),
34 array( '11000', '220', '44', '30', '24', '18', 'o' ),
35 array( '11001', '221', '100', '31', '25', '19', 'p' ),
36 array( '11010', '222', '101', '32', '26', '1a', 'q' ),
37 array( '11011', '1000', '102', '33', '27', '1b', 'r' ),
38 array( '11100', '1001', '103', '34', '28', '1c', 's' ),
39 array( '11101', '1002', '104', '35', '29', '1d', 't' ),
40 array( '11110', '1010', '110', '36', '30', '1e', 'u' ),
41 array( '11111', '1011', '111', '37', '31', '1f', 'v' ),
42 array( '100000', '1012', '112', '40', '32', '20', 'w' ),
43 array( '100001', '1020', '113', '41', '33', '21', 'x' ),
44 array( '100010', '1021', '114', '42', '34', '22', 'y' ),
45 array( '100011', '1022', '120', '43', '35', '23', 'z' )
49 /**
50 * @dataProvider provideSingleDigitConversions
52 public function testDigitToBase2( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
53 $this->assertSame( $base2, wfBaseConvert( $base3, '3', '2' ) );
54 $this->assertSame( $base2, wfBaseConvert( $base5, '5', '2' ) );
55 $this->assertSame( $base2, wfBaseConvert( $base8, '8', '2' ) );
56 $this->assertSame( $base2, wfBaseConvert( $base10, '10', '2' ) );
57 $this->assertSame( $base2, wfBaseConvert( $base16, '16', '2' ) );
58 $this->assertSame( $base2, wfBaseConvert( $base36, '36', '2' ) );
61 /**
62 * @dataProvider provideSingleDigitConversions
64 public function testDigitToBase3( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
65 $this->assertSame( $base3, wfBaseConvert( $base2, '2', '3' ) );
66 $this->assertSame( $base3, wfBaseConvert( $base5, '5', '3' ) );
67 $this->assertSame( $base3, wfBaseConvert( $base8, '8', '3' ) );
68 $this->assertSame( $base3, wfBaseConvert( $base10, '10', '3' ) );
69 $this->assertSame( $base3, wfBaseConvert( $base16, '16', '3' ) );
70 $this->assertSame( $base3, wfBaseConvert( $base36, '36', '3' ) );
73 /**
74 * @dataProvider provideSingleDigitConversions
76 public function testDigitToBase5( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
77 $this->assertSame( $base5, wfBaseConvert( $base2, '2', '5' ) );
78 $this->assertSame( $base5, wfBaseConvert( $base3, '3', '5' ) );
79 $this->assertSame( $base5, wfBaseConvert( $base8, '8', '5' ) );
80 $this->assertSame( $base5, wfBaseConvert( $base10, '10', '5' ) );
81 $this->assertSame( $base5, wfBaseConvert( $base16, '16', '5' ) );
82 $this->assertSame( $base5, wfBaseConvert( $base36, '36', '5' ) );
85 /**
86 * @dataProvider provideSingleDigitConversions
88 public function testDigitToBase8( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
89 $this->assertSame( $base8, wfBaseConvert( $base2, '2', '8' ) );
90 $this->assertSame( $base8, wfBaseConvert( $base3, '3', '8' ) );
91 $this->assertSame( $base8, wfBaseConvert( $base5, '5', '8' ) );
92 $this->assertSame( $base8, wfBaseConvert( $base10, '10', '8' ) );
93 $this->assertSame( $base8, wfBaseConvert( $base16, '16', '8' ) );
94 $this->assertSame( $base8, wfBaseConvert( $base36, '36', '8' ) );
97 /**
98 * @dataProvider provideSingleDigitConversions
100 public function testDigitToBase10( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
101 $this->assertSame( $base10, wfBaseConvert( $base2, '2', '10' ) );
102 $this->assertSame( $base10, wfBaseConvert( $base3, '3', '10' ) );
103 $this->assertSame( $base10, wfBaseConvert( $base5, '5', '10' ) );
104 $this->assertSame( $base10, wfBaseConvert( $base8, '8', '10' ) );
105 $this->assertSame( $base10, wfBaseConvert( $base16, '16', '10' ) );
106 $this->assertSame( $base10, wfBaseConvert( $base36, '36', '10' ) );
110 * @dataProvider provideSingleDigitConversions
112 public function testDigitToBase16( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
113 $this->assertSame( $base16, wfBaseConvert( $base2, '2', '16' ) );
114 $this->assertSame( $base16, wfBaseConvert( $base3, '3', '16' ) );
115 $this->assertSame( $base16, wfBaseConvert( $base5, '5', '16' ) );
116 $this->assertSame( $base16, wfBaseConvert( $base8, '8', '16' ) );
117 $this->assertSame( $base16, wfBaseConvert( $base10, '10', '16' ) );
118 $this->assertSame( $base16, wfBaseConvert( $base36, '36', '16' ) );
122 * @dataProvider provideSingleDigitConversions
124 public function testDigitToBase36( $base2, $base3, $base5, $base8, $base10, $base16, $base36 ) {
125 $this->assertSame( $base36, wfBaseConvert( $base2, '2', '36' ) );
126 $this->assertSame( $base36, wfBaseConvert( $base3, '3', '36' ) );
127 $this->assertSame( $base36, wfBaseConvert( $base5, '5', '36' ) );
128 $this->assertSame( $base36, wfBaseConvert( $base8, '8', '36' ) );
129 $this->assertSame( $base36, wfBaseConvert( $base10, '10', '36' ) );
130 $this->assertSame( $base36, wfBaseConvert( $base16, '16', '36' ) );
133 public function testLargeNumber() {
134 $this->assertSame( '1100110001111010000000101110100', wfBaseConvert( 'sd89ys', 36, 2 ) );
135 $this->assertSame( '11102112120221201101', wfBaseConvert( 'sd89ys', 36, 3 ) );
136 $this->assertSame( '12003102232400', wfBaseConvert( 'sd89ys', 36, 5 ) );
137 $this->assertSame( '14617200564', wfBaseConvert( 'sd89ys', 36, 8 ) );
138 $this->assertSame( '1715274100', wfBaseConvert( 'sd89ys', 36, 10 ) );
139 $this->assertSame( '663d0174', wfBaseConvert( 'sd89ys', 36, 16 ) );
142 public static function provideNumbers() {
143 $x = array();
144 $chars = '0123456789abcdefghijklmnopqrstuvwxyz';
145 for ( $i = 0; $i < 50; $i++ ) {
146 $base = mt_rand( 2, 36 );
147 $len = mt_rand( 10, 100 );
149 $str = '';
150 for ( $j = 0; $j < $len; $j++ ) {
151 $str .= $chars[mt_rand( 0, $base - 1 )];
154 $x[] = array( $base, $str );
157 return $x;
161 * @dataProvider provideNumbers
163 public function testIdentity( $base, $number ) {
164 $this->assertSame( $number, wfBaseConvert( $number, $base, $base, strlen( $number ) ) );
167 public function testInvalid() {
168 $this->assertFalse( wfBaseConvert( '101', 1, 15 ) );
169 $this->assertFalse( wfBaseConvert( '101', 15, 1 ) );
170 $this->assertFalse( wfBaseConvert( '101', 37, 15 ) );
171 $this->assertFalse( wfBaseConvert( '101', 15, 37 ) );
172 $this->assertFalse( wfBaseConvert( 'abcde', 10, 11 ) );
173 $this->assertFalse( wfBaseConvert( '12930', 2, 10 ) );
174 $this->assertFalse( wfBaseConvert( '101', 'abc', 15 ) );
175 $this->assertFalse( wfBaseConvert( '101', 15, 'abc' ) );
178 public function testPadding() {
179 $number = "10101010101";
180 $this->assertSame(
181 strlen( $number ) + 5,
182 strlen( wfBaseConvert( $number, 2, 2, strlen( $number ) + 5 ) )
184 $this->assertSame(
185 strlen( $number ),
186 strlen( wfBaseConvert( $number, 2, 2, strlen( $number ) - 5 ) )
190 public function testLeadingZero() {
191 $this->assertSame( '24', wfBaseConvert( '010', 36, 16 ) );
192 $this->assertSame( '37d4', wfBaseConvert( '0b10', 36, 16 ) );
193 $this->assertSame( 'a734', wfBaseConvert( '0x10', 36, 16 ) );