mirror of
https://github.com/flarum/core.git
synced 2025-08-08 01:16:52 +02:00
Ensure that search AND list endpoints are tested for users and discussions
This commit is contained in:
@@ -56,111 +56,19 @@ class ListTest extends TestCase
|
|||||||
$this->assertEquals(1, count($data['data']));
|
$this->assertEquals(1, count($data['data']));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
// /**
|
||||||
* @test
|
// * @test
|
||||||
*/
|
// */
|
||||||
public function can_search_for_author()
|
// public function can_search_for_author()
|
||||||
{
|
// {
|
||||||
$response = $this->send(
|
// $response = $this->send(
|
||||||
$this->request('GET', '/api/discussions')
|
// $this->request('GET', '/api/search/discussions')
|
||||||
->withQueryParams([
|
// ->withQueryParams([
|
||||||
'filter' => ['q' => 'author:normal foo'],
|
// 'filter' => ['q' => 'author:normal foo'],
|
||||||
'include' => 'mostRelevantPost',
|
// 'include' => 'mostRelevantPost',
|
||||||
])
|
// ])
|
||||||
);
|
// );
|
||||||
|
|
||||||
$this->assertEquals(200, $response->getStatusCode());
|
// $this->assertEquals(200, $response->getStatusCode());
|
||||||
}
|
// }
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
*/
|
|
||||||
public function can_search_for_word_in_post()
|
|
||||||
{
|
|
||||||
$this->database()->table('discussions')->insert([
|
|
||||||
['id' => 2, 'title' => 'lightsail in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
|
||||||
['id' => 3, 'title' => 'not in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this->database()->table('posts')->insert([
|
|
||||||
['id' => 2, 'discussion_id' => 2, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>not in text</p></t>'],
|
|
||||||
['id' => 3, 'discussion_id' => 3, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>lightsail in text</p></t>'],
|
|
||||||
]);
|
|
||||||
|
|
||||||
$response = $this->send(
|
|
||||||
$this->request('GET', '/api/discussions')
|
|
||||||
->withQueryParams([
|
|
||||||
'filter' => ['q' => 'lightsail'],
|
|
||||||
'include' => 'mostRelevantPost',
|
|
||||||
])
|
|
||||||
);
|
|
||||||
|
|
||||||
$data = json_decode($response->getBody()->getContents(), true);
|
|
||||||
$ids = array_map(function ($row) {
|
|
||||||
return $row['id'];
|
|
||||||
}, $data['data']);
|
|
||||||
|
|
||||||
// Order-independent comparison
|
|
||||||
$this->assertEquals(['3'], $ids, 'IDs do not match', 0.0, 10, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
*/
|
|
||||||
public function ignores_non_word_characters_when_searching()
|
|
||||||
{
|
|
||||||
$this->database()->table('discussions')->insert([
|
|
||||||
['id' => 2, 'title' => 'lightsail in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
|
||||||
['id' => 3, 'title' => 'not in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this->database()->table('posts')->insert([
|
|
||||||
['id' => 2, 'discussion_id' => 2, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>not in text</p></t>'],
|
|
||||||
['id' => 3, 'discussion_id' => 3, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>lightsail in text</p></t>'],
|
|
||||||
]);
|
|
||||||
|
|
||||||
$response = $this->send(
|
|
||||||
$this->request('GET', '/api/discussions')
|
|
||||||
->withQueryParams([
|
|
||||||
'filter' => ['q' => 'lightsail+'],
|
|
||||||
'include' => 'mostRelevantPost',
|
|
||||||
])
|
|
||||||
);
|
|
||||||
|
|
||||||
$data = json_decode($response->getBody()->getContents(), true);
|
|
||||||
$ids = array_map(function ($row) {
|
|
||||||
return $row['id'];
|
|
||||||
}, $data['data']);
|
|
||||||
|
|
||||||
// Order-independent comparison
|
|
||||||
$this->assertEquals(['3'], $ids, 'IDs do not match', 0.0, 10, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @test
|
|
||||||
*/
|
|
||||||
public function search_for_special_characters_gives_empty_result()
|
|
||||||
{
|
|
||||||
$response = $this->send(
|
|
||||||
$this->request('GET', '/api/discussions')
|
|
||||||
->withQueryParams([
|
|
||||||
'filter' => ['q' => '*'],
|
|
||||||
'include' => 'mostRelevantPost',
|
|
||||||
])
|
|
||||||
);
|
|
||||||
|
|
||||||
$data = json_decode($response->getBody()->getContents(), true);
|
|
||||||
$this->assertEquals([], $data['data']);
|
|
||||||
|
|
||||||
$response = $this->send(
|
|
||||||
$this->request('GET', '/api/discussions')
|
|
||||||
->withQueryParams([
|
|
||||||
'filter' => ['q' => '@'],
|
|
||||||
'include' => 'mostRelevantPost',
|
|
||||||
])
|
|
||||||
);
|
|
||||||
|
|
||||||
$data = json_decode($response->getBody()->getContents(), true);
|
|
||||||
$this->assertEquals([], $data['data']);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
166
tests/integration/api/discussions/SearchTest.php
Normal file
166
tests/integration/api/discussions/SearchTest.php
Normal file
@@ -0,0 +1,166 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of Flarum.
|
||||||
|
*
|
||||||
|
* For detailed copyright and license information, please view the
|
||||||
|
* LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Flarum\Tests\integration\api\discussions;
|
||||||
|
|
||||||
|
use Carbon\Carbon;
|
||||||
|
use Flarum\Tests\integration\RetrievesAuthorizedUsers;
|
||||||
|
use Flarum\Tests\integration\TestCase;
|
||||||
|
|
||||||
|
class SearchTest extends TestCase
|
||||||
|
{
|
||||||
|
use RetrievesAuthorizedUsers;
|
||||||
|
|
||||||
|
protected function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->prepareDatabase([
|
||||||
|
'discussions' => [
|
||||||
|
['id' => 1, 'title' => __CLASS__, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'first_post_id' => 1, 'comment_count' => 1],
|
||||||
|
],
|
||||||
|
'posts' => [
|
||||||
|
['id' => 1, 'discussion_id' => 1, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>foo bar</p></t>'],
|
||||||
|
],
|
||||||
|
'users' => [
|
||||||
|
$this->normalUser(),
|
||||||
|
],
|
||||||
|
'groups' => [
|
||||||
|
$this->memberGroup(),
|
||||||
|
$this->guestGroup(),
|
||||||
|
],
|
||||||
|
'group_permission' => [
|
||||||
|
['permission' => 'viewDiscussions', 'group_id' => 2],
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function shows_index_for_guest()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true);
|
||||||
|
|
||||||
|
$this->assertEquals(1, count($data['data']));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function can_search_for_author()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['q' => 'author:normal foo'],
|
||||||
|
'include' => 'mostRelevantPost',
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function can_search_for_word_in_post()
|
||||||
|
{
|
||||||
|
$this->database()->table('discussions')->insert([
|
||||||
|
['id' => 2, 'title' => 'lightsail in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
||||||
|
['id' => 3, 'title' => 'not in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->database()->table('posts')->insert([
|
||||||
|
['id' => 2, 'discussion_id' => 2, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>not in text</p></t>'],
|
||||||
|
['id' => 3, 'discussion_id' => 3, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>lightsail in text</p></t>'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['q' => 'lightsail'],
|
||||||
|
'include' => 'mostRelevantPost',
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true);
|
||||||
|
$ids = array_map(function ($row) {
|
||||||
|
return $row['id'];
|
||||||
|
}, $data['data']);
|
||||||
|
|
||||||
|
// Order-independent comparison
|
||||||
|
$this->assertEquals(['3'], $ids, 'IDs do not match', 0.0, 10, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function ignores_non_word_characters_when_searching()
|
||||||
|
{
|
||||||
|
$this->database()->table('discussions')->insert([
|
||||||
|
['id' => 2, 'title' => 'lightsail in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
||||||
|
['id' => 3, 'title' => 'not in title', 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'comment_count' => 1],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->database()->table('posts')->insert([
|
||||||
|
['id' => 2, 'discussion_id' => 2, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>not in text</p></t>'],
|
||||||
|
['id' => 3, 'discussion_id' => 3, 'created_at' => Carbon::now()->toDateTimeString(), 'user_id' => 2, 'type' => 'comment', 'content' => '<t><p>lightsail in text</p></t>'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['q' => 'lightsail+'],
|
||||||
|
'include' => 'mostRelevantPost',
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true);
|
||||||
|
$ids = array_map(function ($row) {
|
||||||
|
return $row['id'];
|
||||||
|
}, $data['data']);
|
||||||
|
|
||||||
|
// Order-independent comparison
|
||||||
|
$this->assertEquals(['3'], $ids, 'IDs do not match', 0.0, 10, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function search_for_special_characters_gives_empty_result()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['q' => '*'],
|
||||||
|
'include' => 'mostRelevantPost',
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true);
|
||||||
|
$this->assertEquals([], $data['data']);
|
||||||
|
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/discussions')
|
||||||
|
->withQueryParams([
|
||||||
|
'filter' => ['q' => '@'],
|
||||||
|
'include' => 'mostRelevantPost',
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$data = json_decode($response->getBody()->getContents(), true);
|
||||||
|
$this->assertEquals([], $data['data']);
|
||||||
|
}
|
||||||
|
}
|
83
tests/integration/api/users/SearchTest.php
Normal file
83
tests/integration/api/users/SearchTest.php
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of Flarum.
|
||||||
|
*
|
||||||
|
* For detailed copyright and license information, please view the
|
||||||
|
* LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Flarum\Tests\integration\api\users;
|
||||||
|
|
||||||
|
use Flarum\Group\Permission;
|
||||||
|
use Flarum\Tests\integration\RetrievesAuthorizedUsers;
|
||||||
|
use Flarum\Tests\integration\TestCase;
|
||||||
|
|
||||||
|
class SearchTest extends TestCase
|
||||||
|
{
|
||||||
|
use RetrievesAuthorizedUsers;
|
||||||
|
|
||||||
|
protected function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
$this->prepareDatabase([
|
||||||
|
'users' => [
|
||||||
|
$this->adminUser(),
|
||||||
|
],
|
||||||
|
'groups' => [
|
||||||
|
$this->adminGroup(),
|
||||||
|
$this->guestGroup(),
|
||||||
|
],
|
||||||
|
'group_permission' => [],
|
||||||
|
'group_user' => [
|
||||||
|
['user_id' => 1, 'group_id' => 1],
|
||||||
|
],
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function disallows_index_for_guest()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/users')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(403, $response->getStatusCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function shows_index_for_guest_when_they_have_permission()
|
||||||
|
{
|
||||||
|
Permission::unguarded(function () {
|
||||||
|
Permission::create([
|
||||||
|
'permission' => 'viewUserList',
|
||||||
|
'group_id' => 2,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/users')
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function shows_index_for_admin()
|
||||||
|
{
|
||||||
|
$response = $this->send(
|
||||||
|
$this->request('GET', '/api/search/users', [
|
||||||
|
'authenticatedAs' => 1,
|
||||||
|
])
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(200, $response->getStatusCode());
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user