feat-add-kasmasuk-with-userid
WMS API/ERP-API/pipeline/head This commit looks good Details

This commit is contained in:
Hegifebrianto 2025-02-14 16:01:27 +07:00
parent ed7182f9fd
commit 16ca1e9c01
8 changed files with 264 additions and 4 deletions

View File

@ -0,0 +1,79 @@
<?php
namespace App\Http\Controllers;
use App\Models\KasMasuk;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Auth;
class KasMasukController extends Controller
{
// 1. List All Entries
public function index()
{
$kasMasuk = KasMasuk::with('user')->get();
return response()->json($kasMasuk, Response::HTTP_OK);
}
// 2. Create New Entry
public function store(Request $request)
{
$request->validate([
'tanggal' => 'required|date',
'deskripsi' => 'required|string',
'jumlah' => 'required|numeric|min:0',
]);
$kasMasuk = KasMasuk::create([
'user_id' => Auth::id(), // Ambil user yang sedang login
'tanggal' => $request->tanggal,
'deskripsi' => $request->deskripsi,
'jumlah' => $request->jumlah,
]);
return response()->json($kasMasuk, Response::HTTP_CREATED);
}
// 3. Show Specific Entry
public function show($id)
{
$kasMasuk = KasMasuk::with('user')->find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
return response()->json($kasMasuk, Response::HTTP_OK);
}
// 4. Update Entry
public function update(Request $request, $id)
{
$kasMasuk = KasMasuk::find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
$request->validate([
'tanggal' => 'sometimes|date',
'deskripsi' => 'sometimes|string',
'jumlah' => 'sometimes|numeric|min:0',
]);
$kasMasuk->update($request->all());
return response()->json($kasMasuk, Response::HTTP_OK);
}
// 5. Delete Entry
public function destroy($id)
{
$kasMasuk = KasMasuk::find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
$kasMasuk->delete();
return response()->json(['message' => 'Data berhasil dihapus'], Response::HTTP_OK);
}
}

23
app/Models/KasMasuk.php Normal file
View File

@ -0,0 +1,23 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
class KasMasuk extends Model
{
use HasFactory;
protected $fillable = ['user_id', 'tanggal', 'deskripsi', 'jumlah'];
/**
* Relasi ke user (siapa yang membuat transaksi).
*/
public function user(): BelongsTo
{
return $this->belongsTo(User::class);
}
}

View File

@ -0,0 +1,20 @@
<?php
namespace Database\Factories;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
* @extends \Illuminate\Database\Eloquent\Factories\Factory<\App\Models\KasMasuk>
*/
class KasMasukFactory extends Factory
{
public function definition()
{
return [
'tanggal' => $this->faker->date(),
'deskripsi' => $this->faker->sentence(),
'jumlah' => $this->faker->randomNumber(6),
];
}
}

View File

@ -0,0 +1,26 @@
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration {
public function up()
{
Schema::create('kas_masuks', function (Blueprint $table) {
$table->id();
$table->unsignedBigInteger('user_id'); // Metadata siapa yang membuat
$table->date('tanggal');
$table->string('deskripsi');
$table->float('jumlah', 15, 2); // Ubah dari decimal ke float
$table->timestamps();
// Foreign key ke tabel users
$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
});
}
public function down()
{
Schema::dropIfExists('kas_masuks');
}
};

View File

@ -0,0 +1,17 @@
<?php
namespace Database\Seeders;
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
use Illuminate\Database\Seeder;
class KasMasukSeeder extends Seeder
{
/**
* Run the database seeds.
*/
public function run(): void
{
//
}
}

View File

@ -4,14 +4,25 @@ namespace Database\Seeders;
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
use Illuminate\Database\Seeder;
use App\Models\User;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
class UserSeeder extends Seeder
{
/**
* Run the database seeds.
*/
public function run(): void
{
//
User::create([
'name' => 'John Doe',
'email' => 'johndoe@example.com',
'password' => Hash::make('password123'),
'email_verified_at' => now(),
'remember_token' => Str::random(10),
'created_at' => now(),
'updated_at' => now(),
]);
}
}

View File

@ -2,6 +2,7 @@
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Route;
use App\Http\Controllers\KasMasukController;
/*
|--------------------------------------------------------------------------
@ -17,3 +18,9 @@ use Illuminate\Support\Facades\Route;
Route::middleware('auth:sanctum')->get('/user', function (Request $request) {
return $request->user();
});
// Route::apiResource(name: 'kas-masuk', KasMasukController::class);
Route::middleware('auth:sanctum')->group(function () {
Route::apiResource('kas-masuk', KasMasukController::class);
});

View File

@ -0,0 +1,77 @@
<?php
namespace Tests\Unit;
use App\Models\KasMasuk;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Tests\TestCase;
class KasMasukTest extends TestCase
{
use RefreshDatabase; // Menggunakan database testing
/** @test */
public function it_can_list_all_kas_masuk()
{
KasMasuk::factory()->count(3)->create();
$response = $this->getJson('/api/kas-masuk');
$response->assertStatus(200)
->assertJsonCount(3);
}
/** @test */
public function it_can_create_a_kas_masuk_entry()
{
$data = [
'tanggal' => now()->toDateString(),
'deskripsi' => 'Pemasukan dari pelanggan',
'jumlah' => 1000000,
];
$response = $this->postJson('/api/kas-masuk', $data);
$response->assertStatus(201)
->assertJsonFragment(['deskripsi' => 'Pemasukan dari pelanggan']);
}
/** @test */
public function it_can_get_a_specific_kas_masuk_entry()
{
$kasMasuk = KasMasuk::factory()->create();
$response = $this->getJson("/api/kas-masuk/{$kasMasuk->id}");
$response->assertStatus(200)
->assertJsonFragment(['deskripsi' => $kasMasuk->deskripsi]);
}
/** @test */
public function it_can_update_a_kas_masuk_entry()
{
$kasMasuk = KasMasuk::factory()->create();
$updateData = [
'deskripsi' => 'Pemasukan dari investasi',
'jumlah' => 2000000
];
$response = $this->putJson("/api/kas-masuk/{$kasMasuk->id}", $updateData);
$response->assertStatus(200)
->assertJsonFragment(['deskripsi' => 'Pemasukan dari investasi']);
}
/** @test */
public function it_can_delete_a_kas_masuk_entry()
{
$kasMasuk = KasMasuk::factory()->create();
$response = $this->deleteJson("/api/kas-masuk/{$kasMasuk->id}");
$response->assertStatus(200);
$this->assertDatabaseMissing('kas_masuks', ['id' => $kasMasuk->id]);
}
}