Apabila bekerja pada projek Java, pengelogan ialah alat penting untuk nyahpepijat dan memahami gelagat aplikasi. Dalam sesetengah kes, anda mungkin mahu menulis ujian yang mengesahkan mesej log tertentu dihasilkan dalam keadaan tertentu. Berikut ialah panduan mudah untuk mencapainya menggunakan SLF4J dengan Log Balik dan TestLogAppender tersuai.
Menyediakan Contoh
Kami akan membuat perkhidmatan asas yang mencatat ralat apabila pengecualian berlaku dan ujian yang sepadan untuk mengesahkan mesej log.
Langkah 1: Tambah Ketergantungan Ujian Log Balik
... <dependency> <groupid>ch.qos.logback</groupid> <artifactid>logback-core</artifactid> <scope>test</scope> </dependency> ...
Langkah 2: Melaksanakan Perkhidmatan
Berikut ialah perkhidmatan ringkas yang menangkap pengecualian dan mencatat ralat:
package com.example.loggingdemo; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class SimpleService { private static final Logger logger = LoggerFactory.getLogger(SimpleService.class); public void performTask() { try { // Simulate some task that fails throw new IllegalArgumentException("Simulated exception"); } catch (IllegalArgumentException e) { logger.error("An error occurred: {}", e.getMessage()); } } }
Langkah 3: Mencipta TestLogAppender Tersuai
Pelampir ini menangkap mesej log semasa ujian, membolehkan penegasan pada kandungannya.
package com.example.loggingdemo; import ch.qos.logback.classic.spi.ILoggingEvent; import ch.qos.logback.core.AppenderBase; public class TestLogAppender extends AppenderBase<iloggingevent> { private final StringBuilder logs = new StringBuilder(); @Override protected void append(ILoggingEvent eventObject) { logs.append(eventObject.getFormattedMessage()).append(" "); } public String getLogs() { return logs.toString(); } } </iloggingevent>
Langkah 4: Menulis Ujian
Sekarang, mari tulis ujian untuk mengesahkan output log.
package com.example.loggingdemo; import static org.assertj.core.api.Assertions.assertThat; import ch.qos.logback.classic.Logger; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.slf4j.LoggerFactory; public class SimpleServiceTest { private TestLogAppender logAppender; private SimpleService simpleService; @BeforeEach public void setup() { // Attach TestLogAppender to the logger logAppender = new TestLogAppender(); logAppender.start(); Logger logger = (Logger) LoggerFactory.getLogger(SimpleService.class); logger.addAppender(logAppender); // Initialize the service simpleService = new SimpleService(); } @Test public void testPerformTaskLogsError() { // Act simpleService.performTask(); // Assert String logs = logAppender.getLogs(); assertThat(logs).contains("An error occurred: Simulated exception"); } }
Penting
Jangan lupa mulakan lampiran log anda!
Langkah 5: Menjalankan Ujian
Apabila anda menjalankan ujian ini, ia akan mengesahkan bahawa SimpleService mencatatkan mesej ralat yang dijangkakan apabila pengecualian berlaku.
Bagaimana Ia Berfungsi
- Pelampir Tersuai: TestLogAppender menangkap mesej log dengan mengatasi kaedah tambahan AppenderBase Logback.
- Konfigurasi Logger: Semasa ujian, kami melampirkan penambah tersuai secara dinamik pada pembalak sasaran.
- Penegasan pada Log: Gunakan log yang ditangkap untuk penegasan dalam ujian anda, mengesahkan mesej atau corak tertentu.
Kesimpulan
Dengan pendekatan ini, anda boleh menguji tingkah laku pengelogan anda dengan yakin, memastikan aplikasi anda merekodkan peristiwa dan ralat penting seperti yang dijangkakan. Persediaan ini serba boleh dan boleh disesuaikan dengan senario yang lebih kompleks, seperti menguji tahap log atau pemformatan mesej.
Jangan ragu untuk mencuba ini dan menyesuaikannya dengan projek anda sendiri!
Selamat pengekodan!
Atas ialah kandungan terperinci Menangkap dan Menguji Log dalam Java dengan SLFand Logback: Panduan Mudah. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai

Artikel ini meneroka mengintegrasikan pengaturcaraan berfungsi ke dalam Java menggunakan ekspresi Lambda, API Streams, rujukan kaedah, dan pilihan. Ia menyoroti faedah seperti kebolehbacaan dan kebolehkerjaan kod yang lebih baik melalui kesimpulan dan kebolehubahan

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini menerangkan NIO API Java untuk I/O yang tidak menyekat, menggunakan pemilih dan saluran untuk mengendalikan pelbagai sambungan dengan cekap dengan satu benang. Ia memperincikan proses, faedah (skalabilitas, prestasi), dan potensi perangkap (kerumitan,

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini memperincikan API soket Java untuk komunikasi rangkaian, yang meliputi persediaan pelanggan-pelayan, pengendalian data, dan pertimbangan penting seperti pengurusan sumber, pengendalian ralat, dan keselamatan. Ia juga meneroka teknik pengoptimuman prestasi, i


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),