LogFormatterTestCase.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. /**
  3. * @since 1.26
  4. */
  5. abstract class LogFormatterTestCase extends MediaWikiLangTestCase {
  6. public function doTestLogFormatter( $row, $extra ) {
  7. RequestContext::resetMain();
  8. $row = $this->expandDatabaseRow( $row, $this->isLegacy( $extra ) );
  9. $formatter = LogFormatter::newFromRow( $row );
  10. $this->assertEquals(
  11. $extra['text'],
  12. self::removeSomeHtml( $formatter->getActionText() ),
  13. 'Action text is equal to expected text'
  14. );
  15. $this->assertSame( // ensure types and array key order
  16. $extra['api'],
  17. self::removeApiMetaData( $formatter->formatParametersForApi() ),
  18. 'Api log params is equal to expected array'
  19. );
  20. }
  21. protected function isLegacy( $extra ) {
  22. return isset( $extra['legacy'] ) && $extra['legacy'];
  23. }
  24. protected function expandDatabaseRow( $data, $legacy ) {
  25. return [
  26. // no log_id because no insert in database
  27. 'log_type' => $data['type'],
  28. 'log_action' => $data['action'],
  29. 'log_timestamp' => $data['timestamp'] ?? wfTimestampNow(),
  30. 'log_user' => $data['user'] ?? 0,
  31. 'log_user_text' => $data['user_text'] ?? 'User',
  32. 'log_actor' => $data['actor'] ?? 0,
  33. 'log_namespace' => $data['namespace'] ?? NS_MAIN,
  34. 'log_title' => $data['title'] ?? 'Main_Page',
  35. 'log_page' => $data['page'] ?? 0,
  36. 'log_comment_text' => $data['comment'] ?? '',
  37. 'log_comment_data' => null,
  38. 'log_params' => $legacy
  39. ? LogPage::makeParamBlob( $data['params'] )
  40. : LogEntryBase::makeParamBlob( $data['params'] ),
  41. 'log_deleted' => $data['deleted'] ?? 0,
  42. ];
  43. }
  44. private static function removeSomeHtml( $html ) {
  45. $html = str_replace( '&quot;', '"', $html );
  46. $html = preg_replace( '/\xE2\x80[\x8E\x8F]/', '', $html ); // Strip lrm/rlm
  47. return trim( strip_tags( $html ) );
  48. }
  49. private static function removeApiMetaData( $val ) {
  50. if ( is_array( $val ) ) {
  51. unset( $val['_element'] );
  52. unset( $val['_type'] );
  53. foreach ( $val as $key => $value ) {
  54. $val[$key] = self::removeApiMetaData( $value );
  55. }
  56. }
  57. return $val;
  58. }
  59. }