@ -43,7 +43,8 @@ final class MDPuqi {
|
||||
public const QI_REWARD_DESCRIPTION_LENGTH_GOOD = 3;
|
||||
private const QI_REWARD_DESCRIPTION_LENGTH_GREAT = 6;
|
||||
private const QI_REWARD_EVENTS_MULTIPLIER = 5;
|
||||
private const QI_REWARD_TAGS_MULTIPLIER = 3;
|
||||
public const QI_REWARD_TAGS_MULTIPLIER = 3;
|
||||
public const QI_REWARD_TAGS_MULTIPLIER_ABOVE_THRESHOLD = 1;
|
||||
private const QI_REWARD_LITERATURE_MULTIPLIER = 2;
|
||||
private const QI_REWARD_HYPERLINKS_MULTIPLIER = 2;
|
||||
private const QI_REWARD_DOCUMENTS_MULTIPLIER = 1;
|
||||
@ -80,11 +81,11 @@ final class MDPuqi {
|
||||
private const QI_PENALTY_NO_IMAGE = -10;
|
||||
private const QI_PENALTY_NO_COLLECTION = -10;
|
||||
private const QI_PENALTY_MULTIPLIER_EVENT_PART_DOUBLE_LINKED_AS_RELATED = -10;
|
||||
private const QI_PENALTY_NO_EVENTS = -15;
|
||||
private const QI_PENALTY_NO_TAG = -15;
|
||||
private const QI_PENALTY_ONLY_ONE_TAG = -10;
|
||||
private const QI_PENALTY_ONLY_TWO_TAG = -5;
|
||||
private const QI_PENALTY_TOO_MANY_TAGS = -3; // Per tag of more than 10 tags
|
||||
public const QI_PENALTY_NO_EVENTS = -15;
|
||||
public const QI_PENALTY_NO_TAG = -15;
|
||||
public const QI_PENALTY_ONLY_ONE_TAG = -10;
|
||||
public const QI_PENALTY_ONLY_TWO_TAG = -5;
|
||||
public const QI_PENALTY_TOO_MANY_TAGS = -3; // Per tag of more than 10 tags
|
||||
|
||||
private const QI_PENALTY_IMAGE_FILE_MISSING = -5;
|
||||
private const QI_PENALTY_IMAGE_TOO_SMALL = -5;
|
||||
@ -445,9 +446,9 @@ final class MDPuqi {
|
||||
$value = self::QI_REWARD_TAGS_MULTIPLIER * $anzahl_swoergebnis;
|
||||
}
|
||||
else {
|
||||
$msg = $this->_tlLoader->tl("quality", "quality", "too_many__tags");
|
||||
$status = MDPuqiMessageStatus::warning;
|
||||
$value = self::QI_PENALTY_TOO_MANY_TAGS * ($anzahl_swoergebnis - 10);
|
||||
$msg = $this->_tlLoader->tl("quality", "quality", "tree_nine__tags");
|
||||
$status = MDPuqiMessageStatus::praise;
|
||||
$value = self::QI_REWARD_TAGS_MULTIPLIER * self::THRESHOLD_TAGS_TOO_MANY + ($anzahl_swoergebnis - self::THRESHOLD_TAGS_TOO_MANY) * self::QI_REWARD_TAGS_MULTIPLIER_ABOVE_THRESHOLD;
|
||||
}
|
||||
|
||||
$this->_messages[] = new MDPuqiMessage(
|
||||
|
@ -82,4 +82,41 @@ final class MDPuqiTest extends TestCase {
|
||||
self::assertEquals($positive, $score > 0, "Expected score to be positive or negative, got the oppite result. Score is: " . $score);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Data provider for tag.
|
||||
* 0: Input number of tags.
|
||||
* 1: Expected score.
|
||||
*
|
||||
* @return Generator<array{0: int, 1: int}>
|
||||
*/
|
||||
public static function tagNoAndScoreProvider():Generator {
|
||||
|
||||
yield 'No tags' => [0, 0 + MDPuqi::QI_PENALTY_NO_TAG];
|
||||
yield 'One tag' => [1, 0 + MDPuqi::QI_PENALTY_ONLY_ONE_TAG];
|
||||
yield 'Two tag' => [2, 0 + MDPuqi::QI_PENALTY_ONLY_TWO_TAG];
|
||||
yield 'Regular number of tags' => [5, 0 + 5 * MDPuqi::QI_REWARD_TAGS_MULTIPLIER];
|
||||
yield 'Number of tags above threshold' => [MDPuqi::THRESHOLD_TAGS_TOO_MANY + 1, 0 + MDPuqi::THRESHOLD_TAGS_TOO_MANY * MDPuqi::QI_REWARD_TAGS_MULTIPLIER + 1 * MDPuqi::QI_REWARD_TAGS_MULTIPLIER_ABOVE_THRESHOLD];
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Test for tag evaluation.
|
||||
*
|
||||
* @param integer $noOfTags Input number of tags.
|
||||
* @param integer $expectedScore Expected score.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
#[DataProvider('tagNoAndScoreProvider')]
|
||||
public function testTagEvaluation(int $noOfTags, int $expectedScore):void {
|
||||
|
||||
$puqi = new MDPuqi(new MDTlLoader("abc", "en"));
|
||||
$puqi->checkEvents([], [], [], [], $noOfTags);
|
||||
$msgs = $puqi->getMessages();
|
||||
|
||||
$score = $puqi->getScore();
|
||||
self::assertEquals(MDPuqi::QI_PENALTY_NO_EVENTS + $expectedScore, $score, "Tag eval: Score differs from expected. Messages: " . var_export($puqi->getMessages(), true));
|
||||
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user