タグを保存前に正規化する

This commit is contained in:
shibafu 2020-02-22 14:39:25 +09:00
parent cb0af4113d
commit 631d2ea298
4 changed files with 61 additions and 2 deletions

View File

@ -44,7 +44,7 @@ class CardController
]); ]);
$tagIds = []; $tagIds = [];
foreach ($resolved->tags as $tagName) { foreach ($resolved->normalizedTags() as $tagName) {
$tag = Tag::firstOrCreate(['name' => $tagName]); $tag = Tag::firstOrCreate(['name' => $tagName]);
$tagIds[] = $tag->id; $tagIds[] = $tag->id;
} }

View File

@ -56,7 +56,7 @@ class LinkCollector
]); ]);
$tagIds = []; $tagIds = [];
foreach ($resolved->tags as $tagName) { foreach ($resolved->normalizedTags() as $tagName) {
$tag = Tag::firstOrCreate(['name' => $tagName]); $tag = Tag::firstOrCreate(['name' => $tagName]);
$tagIds[] = $tag->id; $tagIds[] = $tag->id;
} }

View File

@ -23,4 +23,30 @@ class Metadata
* チェックインタグと同様に保存されるため、スペースや改行文字を含めてはいけません。 * チェックインタグと同様に保存されるため、スペースや改行文字を含めてはいけません。
*/ */
public $tags = []; public $tags = [];
/**
* 重複を排除し、正規化を行ったタグの集合を返します。
* @return string[]
*/
public function normalizedTags(): array
{
$tags = [];
foreach ($this->tags as $tag) {
$tag = $this->sanitize($tag);
$tag = $this->trim($tag);
$tags[$tag] = true;
}
return array_keys($tags);
}
private function sanitize(string $value): string
{
return preg_replace('/\r?\n/u', ' ', $value);
}
private function trim(string $value): string
{
return trim($value);
}
} }

View File

@ -0,0 +1,33 @@
<?php
namespace Tests\Unit\MetadataResolver;
use App\MetadataResolver\Metadata;
use Tests\TestCase;
class MetadataTest extends TestCase
{
public function testNormalizedTagsCanTrim()
{
$metadata = new Metadata();
$metadata->tags = ['foo ', ' bar', ' foo bar '];
$this->assertEquals(['foo', 'bar', 'foo bar'], $metadata->normalizedTags());
}
public function testNormalizedTagsCanSanitize()
{
$metadata = new Metadata();
$metadata->tags = ["foo \n", " \nbar", " foo\n bar "];
$this->assertEquals(['foo', 'bar', 'foo bar'], $metadata->normalizedTags());
}
public function testNormalizedTagsCanDeduplication()
{
$metadata = new Metadata();
$metadata->tags = ['foo ', ' foo', ' bar'];
$this->assertEquals(['foo', 'bar'], $metadata->normalizedTags());
}
}