Providing the function name is often optional from the php code, but it is needed for better logging, so make it mandatory and let phan report issues about this. Bug: T374546 Depends-On: Iaed5489a85a5a6e685829e151436afc94310fbd0 Depends-On: Ie2a1e5052e5b61bbb5b89905de942f47d3f1413d Change-Id: I5227f2fa65850ac8c6f620900f22d1f4e7bfd470
74 lines
2.5 KiB
PHP
74 lines
2.5 KiB
PHP
<?php
|
|
|
|
// phpcs:disable
|
|
|
|
/*
|
|
* Some RDBMS interfaces have methods with rather complicated Phan annotations. This test ensures
|
|
* that future versions of Phan still handle them correctly, and that future developers don't mess
|
|
* them up.
|
|
*
|
|
* If Phan reports new issues or unused suppressions in this file, DO NOT just fix the errors,
|
|
* and instead make sure that your patch is not breaking the annotations.
|
|
*/
|
|
|
|
die( 'This file should never be loaded' );
|
|
|
|
class RdbmsTypeHintsTest {
|
|
function testExpr( \Wikimedia\Rdbms\IDatabase $db ) {
|
|
$conds = [];
|
|
|
|
$expr = $db->expr( 'a', '=', 1 );
|
|
// Return value of ->and() etc. must be used
|
|
// @phan-suppress-next-line PhanPluginUseReturnValueKnown
|
|
$expr->and( 'a', '=', 1 );
|
|
|
|
// Typo in the operator
|
|
// @phan-suppress-next-line PhanTypeMismatchArgumentProbablyReal
|
|
$conds[] = $db->expr( 'a', '=<', 1 );
|
|
|
|
// We accept lots of types, but not all
|
|
// @phan-suppress-next-line PhanTypeMismatchArgumentProbablyReal
|
|
$conds[] = $db->expr( 'a', '=', new \stdClass );
|
|
|
|
// Empty arrays are not allowed
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$conds[] = $db->expr( 'a', '=', [] );
|
|
|
|
// Null in arrays is not allowed (unlike in the `$qb->where( 'a' => [ ... ] )` syntax)
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$conds[] = $db->expr( 'a', '=', [ 1, null, 2 ] );
|
|
|
|
// Associative arrays are not allowed
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$conds[] = $db->expr( 'a', '=', [ 'a' => 1, 'b' => 2 ] );
|
|
|
|
// Arrays with gaps are not allowed (unlike in the `$qb->where( 'a' => [ ... ] )` syntax)
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$conds[] = $db->expr( 'a', '=', array_unique( [ 1, 1, 2, 2 ] ) );
|
|
}
|
|
|
|
/**
|
|
* @suppress PhanParamTooFewInPHPDoc
|
|
*/
|
|
function testSelectConds( \Wikimedia\Rdbms\IDatabase $db ) {
|
|
// Missing key for array value
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$db->select( 'a', 'b', [ [ 1, 2, 3 ] ] );
|
|
|
|
// Empty array value
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$db->select( 'a', 'b', [ 'x' => [] ] );
|
|
|
|
// Unexpected key for IExpression value
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$db->select( 'a', 'b', [ 'x' => $db->expr( 'x', '=', 1 ) ] );
|
|
|
|
// Nested array in array value
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$db->select( 'a', 'b', [ 'x' => [ 1, 2, [ 3 ] ] ] );
|
|
|
|
// Associative arrays are not allowed
|
|
// @phan-suppress-next-line PhanTypeMismatchArgument
|
|
$db->select( 'a', 'b', [ 'x' => [ 'a' => 1, 'b' => 2 ] ] );
|
|
}
|
|
}
|