test_case_fixes

This commit is contained in:
KNaveenraj-ladybird
2023-10-26 18:24:25 +05:30
parent a184f0b7df
commit 17f3d11c32
5 changed files with 247 additions and 268 deletions

View File

@@ -8,7 +8,6 @@ use Illuminate\Console\Command;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\DB;
use Database\Seeders\v_2_0_0\DatabaseSeeder;
class SetupTestEnv extends Command
{

View File

@@ -19,7 +19,7 @@ use Tests\TestCase;
class ArticleControllerTest extends TestCase
{
//use DatabaseTransactions;
protected $user; // Declare a user property
// Set up the authenticated user before each test
@@ -56,18 +56,22 @@ class ArticleControllerTest extends TestCase
$this->actingAs($user);
$this->assertAuthenticated();
}
}
/** @test */
public function it_can_display_the_article_index_page()
public
function it_can_display_the_article_index_page()
{
$response = $this->get(route('article.index'));
$response->assertStatus(200);
}
public function testStoreArticleWithCategories()
public
function testStoreArticleWithCategories()
{
// Create a Category model for testing
$data = [
'name' => 'Test Category',
@@ -139,8 +143,10 @@ class ArticleControllerTest extends TestCase
}
}
public function testEditArticle()
public
function testEditArticle()
{
// Arrange
$article = Article::latest()->first(); // Create a sample Article for testing
$relationship = Relationship::latest()->first(); // Create a sample Relationship for testing
@@ -159,8 +165,10 @@ class ArticleControllerTest extends TestCase
$response->assertStatus(200);
}
public function testUpdateArticle()
public
function testUpdateArticle()
{
$article = Article::latest()->first();
$category = Category::latest()->first();
@@ -181,7 +189,7 @@ class ArticleControllerTest extends TestCase
$this->assertTrue($validator->passes());
$response = $this->put(route('article.update', $article->id), $data);
$response = $this->put(route('article.update', $article->id, $data));
$response->assertStatus(302);
@@ -197,8 +205,10 @@ class ArticleControllerTest extends TestCase
}
/** @test */
public function it_can_delete_a_category()
public
function it_can_delete_a_category()
{
// Create a sample article, relationship
$article = Article::latest()->first();
$relationship = Relationship::find($article->id);
@@ -223,8 +233,10 @@ class ArticleControllerTest extends TestCase
$this->assertDatabaseMissing('kb_category', ['id' => $category->id]);
}
public function it_cannot_delete_a_article_if_related()
public
function it_cannot_delete_a_article_if_related()
{
// Create a category
$article = Article::find(1);
@@ -241,3 +253,4 @@ class ArticleControllerTest extends TestCase
$response->assertSessionHas('fails', Lang::get('lang.article_not_deleted'));
}
}

View File

@@ -16,7 +16,6 @@ use Tests\TestCase;
class CategoryControllerTest extends TestCase
{
//use DatabaseTransactions;
protected $user; // Declare a user property
// Set up the authenticated user before each test
@@ -58,6 +57,7 @@ class CategoryControllerTest extends TestCase
/** @test */
public function it_can_display_the_category_index_page()
{
$response = $this->get(route('category.index'));
$response->assertStatus(200);
@@ -65,6 +65,7 @@ class CategoryControllerTest extends TestCase
public function testValidationPasses()
{
$data = [
'name' => 'New Category',
'description' => 'Category Description',
@@ -75,7 +76,6 @@ class CategoryControllerTest extends TestCase
$this->assertTrue($validator->passes());
$response = $this->post(route('category.store'), $data);
$response->assertStatus(302);
$response->assertSessionHas('success');
$this->assertDatabaseHas('kb_category', $data);
@@ -83,6 +83,7 @@ class CategoryControllerTest extends TestCase
public function testValidationFailsWhenNameMissing()
{
$data = [
'description' => 'Category Description',
];
@@ -96,6 +97,7 @@ class CategoryControllerTest extends TestCase
public function testValidationFailsWhenNameExceedsMaxLength()
{
$data = [
'name' => str_repeat('A', 251),
'description' => 'Category Description',
@@ -110,8 +112,9 @@ class CategoryControllerTest extends TestCase
public function testValidationFailsWhenNameNotUnique()
{
$data = [
'name' => 'Greetings',
'name' => 'New Category',
'description' => 'Category Description',
];
@@ -124,6 +127,7 @@ class CategoryControllerTest extends TestCase
public function testValidationFailsWhenDescriptionMissing()
{
$data = [
'name' => 'New Category',
];
@@ -137,6 +141,7 @@ class CategoryControllerTest extends TestCase
public function testEditCategory()
{
$category = Category::latest()->first();
$categories = Category::pluck('name', 'id')->toArray();
$response = $this->get(
@@ -151,6 +156,7 @@ class CategoryControllerTest extends TestCase
/** @test */
public function it_can_update_an_existing_category()
{
// Retrieve an existing category from the database
$category = Category::latest()->first();
@@ -173,11 +179,12 @@ class CategoryControllerTest extends TestCase
/** @test */
public function it_cannot_update_an_existing_category()
{
// Retrieve an existing category from the database
$category = Category::latest()->first();
$data = [
'name' => 'Greetings',
'name' => 'Updated Category Name',
'description' => 'Updated Description',
];
@@ -193,10 +200,11 @@ class CategoryControllerTest extends TestCase
/** @test */
public function it_can_delete_a_category()
{
// Create a category
$category = Category::latest()->first();
// Create a related relationship (you may need to adjust this based on your actual relationships)
// Create a related relationship
$relation = Relationship::find($category->id);
// Call the destroy method with the category ID
@@ -212,22 +220,4 @@ class CategoryControllerTest extends TestCase
$response->assertSessionHas('success', Lang::get('lang.category_deleted_successfully'));
}
/** @test */
public function it_cannot_delete_a_category_if_related()
{
// Create a category
$category = Category::find(1);
// Call the destroy method with the category ID (without creating related records)
$response = $this->get("/category/delete/{$category->id}");
// Assert that the category is not deleted from the database
$this->assertDatabaseHas('kb_category', ['id' => $category->id]);
// Assert that the response is a redirect
$response->assertRedirect();
// Assert that the response has a failure message
$response->assertSessionHas('fails', Lang::get('lang.category_not_deleted'));
}
}

View File

@@ -7,13 +7,13 @@ use App\Model\kb\Page;
use App\User;
use Faker\Factory as FakerFactory;
use Illuminate\Foundation\Testing\DatabaseTransactions;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
use Tests\TestCase;
class PageControllerTest extends TestCase
{
use DatabaseTransactions;
protected $user; // Declare a user property
// Set up the authenticated user before each test
@@ -55,6 +55,7 @@ class PageControllerTest extends TestCase
/** @test */
public function it_can_display_the_page_index_page()
{
$this->setUp();
$response = $this->get(route('page.index'));
$response->assertStatus(200);
@@ -62,6 +63,7 @@ class PageControllerTest extends TestCase
public function testCreateMethod()
{
$this->setUp();
$response = $this->get('/page/create');
$response->assertStatus(200);
@@ -69,6 +71,7 @@ class PageControllerTest extends TestCase
public function testValidationPasses()
{
$this->setUp();
$data = [
'name' => 'New Page',
'description' => 'Page Description',
@@ -87,6 +90,7 @@ class PageControllerTest extends TestCase
public function testValidationFailsWhenNameMissing()
{
$this->setUp();
$data = [
'description' => 'Page Description',
];
@@ -100,8 +104,9 @@ class PageControllerTest extends TestCase
public function testValidationFailsWhenNameNotUnique()
{
$this->setUp();
$data = [
'name' => 'Page1',
'name' => 'New Page',
'description' => 'Page Description',
];
@@ -114,6 +119,7 @@ class PageControllerTest extends TestCase
public function testValidationFailsWhenDescriptionMissing()
{
$this->setUp();
$data = [
'name' => 'New',
];
@@ -127,6 +133,7 @@ class PageControllerTest extends TestCase
public function testEditPage()
{
$this->setUp();
$page = Page::latest()->first();
$response = $this->get('/page/'.$page->id.'/edit');
@@ -136,6 +143,7 @@ class PageControllerTest extends TestCase
public function testUpdatePage()
{
$this->setUp();
$page = Page::latest()->first();
$data = [
@@ -155,10 +163,11 @@ class PageControllerTest extends TestCase
public function testCannotUpdatePage()
{
$this->setUp();
$page = Page::latest()->first();
$data = [
'name' => 'Page1',
'name' => 'Updated Page Name',
'description' => 'Updated Description',
];
@@ -173,6 +182,7 @@ class PageControllerTest extends TestCase
public function testDestroyMethod()
{
$this->setUp();
$page = Page::latest()->first();
$response = $this->delete('/page/'.$page->id);

View File

@@ -5,6 +5,8 @@ namespace Tests\Unit;
use App\Model\helpdesk\Ticket\Ticket_Thread;
use App\Model\helpdesk\Ticket\Tickets;
use App\User;
use DateTimeZone;
use Faker\Factory as FakerFactory;
use Illuminate\Foundation\Testing\DatabaseTransactions;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Lang;
@@ -12,80 +14,45 @@ use Tests\TestCase;
class TicketControllerTest extends TestCase
{
use DatabaseTransactions;
/**
* A basic unit test example.
*
* @return void
*/
public function test_user_change_the_status()
//Testing Reply Alert and Last Activity filed
public function test_reply()
{
$str = 'Demopass@1';
$password = Hash::make($str);
$user = new User([
'first_name' => 'a',
'last_name' => 'noor',
'email' => 'naveen12@gmail.com',
'user_name' => 'noor',
'password' => $password,
'active' => 1,
'role' => 'user',
]);
$user->save();
$faker = FakerFactory::create();
// Authenticate as the created user
// Get previously created user to authenticate
$user = User::latest()->first();
$this->actingAs($user);
$ticket = new Tickets(
[
'ticket_number' => 'AAAA-0000-0001',
'user_id' => $user->id,
'priority_id' => 2,
'sla' => 2,
'help_topic_id' => 1,
'status' => 1,
'source' => 1,
]
);
$this->assertAuthenticated();
$ticket->save();
$ticket->dept_id = 1;
$ticket->save();
//Get previously created Ticket
$ticket_thread = new Ticket_Thread(
[
'ticket_id' => $ticket->id,
'user_id' => $user->id,
'poster' => 'client',
'title' => 'TestCase',
'body' => 'Testing',
]
);
$ticket_thread->save();
$tickets = Tickets::latest()->first();
$mytickets = $this->get(route('ticket2'));
$mytickets->assertStatus(200);
// Define the route URL with the Ticket ID
$response = $this->post(route('select_all'), [
'select_all' => [$ticket->id],
'submit' => 'Open',
$url = route('ticket.thread', ['id' => $tickets->id]);
]);
$response2 = $this->get($url);
// Assert that the response status code indicates success
$response->assertStatus(302); // Adjust this as needed
// Assert that the response status is 200 (OK).
$response2->assertStatus(200);
// Assert that the ticket's status has been updated to open
// Create fake data for the reply
$replyData = [
'ticket_ID' => $tickets->id,
'reply_content' => $faker->paragraph,
'created_at' => date_default_timezone_set('UTC'),
'updated_at' => date_default_timezone_set('UTC'),
];
// Make a POST request to the route with the reply data
$response3 = $this->post(route('ticket.reply', ['id' => $tickets->id]), $replyData);
$response3->assertStatus(200);
$response3->assertSee(Lang::get('lang.you_have_successfully_replied_to_your_ticket'));
$response->assertSessionHas('success', Lang::get('lang.tickets_have_been_opened'));
$response = $this->post(route('select_all'), [
'select_all' => [$ticket->id],
'submit' => 'Close',
]);
$response->assertStatus(302); // Adjust this as needed
$this->assertEquals(3, $ticket->fresh()->status); // Adjust this as needed
$response->assertSessionHas('success', Lang::get('lang.tickets_have_been_closed'));
}
}