Questions: Moved user tests to user and fixed attribute names, added @covers

This commit is contained in:
Igor Scheller 2019-12-07 21:14:08 +01:00
parent 8fc159f287
commit d6cb9c6258
3 changed files with 54 additions and 56 deletions

View File

@ -33,8 +33,8 @@ function user_questions()
$question = request()->get('question'); $question = request()->get('question');
if (!empty($question) && $request->hasPostData('submit')) { if (!empty($question) && $request->hasPostData('submit')) {
Question::create([ Question::create([
'enquirer_id' => $user->id, 'user_id' => $user->id,
'question' => $question, 'text' => $question,
]); ]);
success(__('You question was saved.')); success(__('You question was saved.'));

View File

@ -52,22 +52,9 @@ class QuestionTest extends TestCase
} }
/** /**
* @return void * @covers \Engelsystem\Models\Question::answerer
*/ */
public function testStoreLoadUnAnsweredQuestion(): void public function testAnswerer(): void
{
$question = $this->createQuestion($this->user1);
$loadedQuestion = Question::find($question->id);
$this->assertSame($this->user1->id, $loadedQuestion->user->id);
$this->assertSame($this->user1->id, $loadedQuestion->user_id);
$this->assertSame($question->text, $loadedQuestion->text);
}
/**
* @return void
*/
public function testStoreLoadAnsweredQuestion(): void
{ {
$question = $this->createQuestion($this->user1, $this->user2); $question = $this->createQuestion($this->user1, $this->user2);
$loadedQuestion = Question::find($question->id); $loadedQuestion = Question::find($question->id);
@ -81,41 +68,7 @@ class QuestionTest extends TestCase
} }
/** /**
* @return void * @covers \Engelsystem\Models\Question::unanswered
*/
public function testUserQuestionsAsked(): void
{
$question1 = $this->createQuestion($this->user1);
$question2 = $this->createQuestion($this->user1);
// create some questions asked by user 2 to test the correct assignment
$this->createQuestion($this->user2);
$this->createQuestion($this->user2);
$user1QuestionIds = $this->user1->questionsAsked()->pluck('id')->toArray();
$this->assertCount(2, $user1QuestionIds);
$this->assertContains($question1->id, $user1QuestionIds);
$this->assertContains($question2->id, $user1QuestionIds);
}
/**
* @return void
*/
public function testUserQuestionsAnswered(): void
{
$question1 = $this->createQuestion($this->user1, $this->user2);
$question2 = $this->createQuestion($this->user1, $this->user2);
// create some questions answered by user 1 to test the correct assignment
$this->createQuestion($this->user2, $this->user1);
$this->createQuestion($this->user2, $this->user1);
$user2Answers = $this->user2->questionsAnswered()->pluck('id')->toArray();
$this->assertCount(2, $user2Answers);
$this->assertContains($question1->id, $user2Answers);
$this->assertContains($question2->id, $user2Answers);
}
/**
* @return void
*/ */
public function testUnanswered(): void public function testUnanswered(): void
{ {
@ -132,7 +85,7 @@ class QuestionTest extends TestCase
} }
/** /**
* @return void * @covers \Engelsystem\Models\Question::answered
*/ */
public function testAnswered(): void public function testAnswered(): void
{ {
@ -149,14 +102,14 @@ class QuestionTest extends TestCase
} }
/** /**
* @param User $enquirer * @param User $user
* @param User|null $answerer * @param User|null $answerer
* @return Question * @return Question
*/ */
private function createQuestion(User $enquirer, ?User $answerer = null): Question private function createQuestion(User $user, ?User $answerer = null): Question
{ {
$data = [ $data = [
'user_id' => $enquirer->id, 'user_id' => $user->id,
'text' => Str::random(), 'text' => Str::random(),
]; ];

View File

@ -5,6 +5,7 @@ namespace Engelsystem\Test\Unit\Models;
use DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts; use DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts;
use Engelsystem\Models\BaseModel; use Engelsystem\Models\BaseModel;
use Engelsystem\Models\News; use Engelsystem\Models\News;
use Engelsystem\Models\Question;
use Engelsystem\Models\User\Contact; use Engelsystem\Models\User\Contact;
use Engelsystem\Models\User\HasUserModel; use Engelsystem\Models\User\HasUserModel;
use Engelsystem\Models\User\PersonalData; use Engelsystem\Models\User\PersonalData;
@ -14,6 +15,7 @@ use Engelsystem\Models\User\User;
use Engelsystem\Test\Unit\HasDatabase; use Engelsystem\Test\Unit\HasDatabase;
use Engelsystem\Test\Unit\TestCase; use Engelsystem\Test\Unit\TestCase;
use Exception; use Exception;
use Illuminate\Support\Str;
class UserTest extends TestCase class UserTest extends TestCase
{ {
@ -146,6 +148,49 @@ class UserTest extends TestCase
]; ];
} }
/**
* @covers \Engelsystem\Models\User\User::questionsAsked
*/
public function testQuestionsAsked(): void
{
($user = new User($this->data))->save();
($user2 = new User(array_merge($this->data, ['name' => 'dolor', 'email' => 'dolor@bar.batz'])))->save();
($question1 = new Question(['user_id' => $user->id, 'text' => Str::random()]))->save();
($question2 = new Question(['user_id' => $user->id, 'text' => Str::random()]))->save();
// create some questions asked by user 2 to test the correct assignment
(new Question(['user_id' => $user2->id, 'text' => Str::random()]))->save();
(new Question(['user_id' => $user2->id, 'text' => Str::random()]))->save();
$questionIds = $user->questionsAsked()->pluck('id')->toArray();
$this->assertCount(2, $questionIds);
$this->assertContains($question1->id, $questionIds);
$this->assertContains($question2->id, $questionIds);
}
/**
* @covers \Engelsystem\Models\User\User::questionsAnswered
*/
public function testQuestionsAnswered(): void
{
($user = new User($this->data))->save();
($user2 = new User(array_merge($this->data, ['name' => 'dolor', 'email' => 'dolor@bar.batz'])))->save();
$questionData = ['user_id' => $user->id, 'text' => Str::random()];
$answerData = ['answerer_id' => $user2->id, 'answer' => Str::random()];
($question1 = new Question(array_merge($questionData, $answerData)))->save();
($question2 = new Question(array_merge($questionData, $answerData)))->save();
// Create some questions asked by user 2 to test the correct assignment
(new Question(array_merge($questionData, $answerData, ['answerer_id' => $user->id])))->save();
(new Question($questionData))->save();
(new Question($questionData))->save();
$answers = $user2->questionsAnswered()->pluck('id')->toArray();
$this->assertCount(2, $answers);
$this->assertContains($question1->id, $answers);
$this->assertContains($question2->id, $answers);
}
/** /**
* Prepare test * Prepare test
*/ */