Java プロジェクトで作業する場合、ログはアプリケーションの動作をデバッグして理解するための重要なツールです。場合によっては、特定のログ メッセージが特定の条件下で生成されることを検証するテストを作成することが必要になる場合があります。 SLF4J と Logback およびカスタム TestLogAppender を使用してこれを達成するための簡単なガイドを次に示します。
サンプルのセットアップ
例外が発生したときにエラーをログに記録する基本的なサービスと、ログ メッセージを検証するための対応するテストを作成します。
ステップ 1: Logback テストの依存関係を追加する
... <dependency> <groupid>ch.qos.logback</groupid> <artifactid>logback-core</artifactid> <scope>test</scope> </dependency> ...
ステップ 2: サービスの実装
これは、例外をキャッチしてエラーを記録する単純なサービスです:
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()); } } }
ステップ 3: カスタム TestLogAppender の作成
このアペンダーはテスト中にログ メッセージをキャプチャし、その内容に対するアサーションを有効にします。
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>
ステップ 4: テストを作成する
次に、ログ出力を検証するテストを作成しましょう。
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"); } }
重要
ログ アペンダを開始することを忘れないでください!
ステップ 5: テストの実行
このテストを実行すると、例外が発生したときに SimpleService が予想されるエラー メッセージをログに記録することが確認されます。
仕組み
- カスタム アペンダー: TestLogAppender は、Logback の AppenderBase の append メソッドをオーバーライドすることでログ メッセージをキャプチャします。
- ロガー構成: テスト中に、カスタム アペンダーをターゲット ロガーに動的に接続します。
- ログ上のアサーション: キャプチャされたログをテストのアサーションに使用し、特定のメッセージまたはパターンを検証します。
結論
このアプローチを使用すると、ログ動作を自信を持ってテストでき、アプリケーションが重要なイベントやエラーを期待どおりにログに記録することができます。この設定は多用途であり、ログ レベルやメッセージの形式のテストなど、より複雑なシナリオに適応できます。
これを自由に試して、独自のプロジェクトに適用してください!
コーディングを楽しんでください!
以上がSLF と Logback を使用した Java でのログのキャプチャとテスト: シンプルなガイドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Javaは、プラットフォームの独立性により、エンタープライズレベルのアプリケーションで広く使用されています。 1)プラットフォームの独立性は、Java Virtual Machine(JVM)を介して実装されているため、Javaをサポートする任意のプラットフォームでコードを実行できます。 2)クロスプラットフォームの展開と開発プロセスを簡素化し、柔軟性とスケーラビリティを高めます。 3)ただし、パフォーマンスの違いとサードパーティライブラリの互換性に注意を払い、純粋なJavaコードやクロスプラットフォームテストの使用などのベストプラクティスを採用する必要があります。

javaplaysasificanificantduetduetoitsplatformindepence.1)itallowscodetobewrittendunonvariousdevices.2)java'secosystemprovidesutionforiot.3)そのセキュリティフィートルセンハンス系

TheSolution to HandlefilepathsaCrosswindossandlinuxinjavaistousepaths.get()fromthejava.nio.filepackage.1)usesystem.getProperty( "user.dir")およびhearterativepathtoconstructurctthefilepath.2)

java'splatformentepenceissificAntiveSifcuseDeverowsDevelowSowRitecodeOdeonceantoniTONAnyPlatformwsajvm.これは「writeonce、runanywhere」(wora)adportoffers:1)クロスプラットフォームの複雑性、deploymentacrossdiferentososwithusisues; 2)re

Javaは、クロスサーバーWebアプリケーションの開発に適しています。 1)Javaの「Write and、Run Averywhere」哲学は、JVMをサポートするあらゆるプラットフォームでコードを実行します。 2)Javaには、開発プロセスを簡素化するために、SpringやHibernateなどのツールを含む豊富なエコシステムがあります。 3)Javaは、パフォーマンスとセキュリティにおいて優れたパフォーマンスを発揮し、効率的なメモリ管理と強力なセキュリティ保証を提供します。

JVMは、バイトコード解釈、プラットフォームに依存しないAPI、動的クラスの負荷を介してJavaのWORA機能を実装します。 2。標準API抽象オペレーティングシステムの違い。 3.クラスは、実行時に動的にロードされ、一貫性を確保します。

Javaの最新バージョンは、JVMの最適化、標準的なライブラリの改善、サードパーティライブラリサポートを通じて、プラットフォーム固有の問題を効果的に解決します。 1)Java11のZGCなどのJVM最適化により、ガベージコレクションのパフォーマンスが向上します。 2)Java9のモジュールシステムなどの標準的なライブラリの改善は、プラットフォーム関連の問題を削減します。 3)サードパーティライブラリは、OpenCVなどのプラットフォーム最適化バージョンを提供します。

JVMのバイトコード検証プロセスには、4つの重要な手順が含まれます。1)クラスファイル形式が仕様に準拠しているかどうかを確認し、2)バイトコード命令の有効性と正確性を確認し、3)データフロー分析を実行してタイプの安全性を確保し、検証の完全性とパフォーマンスのバランスをとる。これらの手順を通じて、JVMは、安全で正しいバイトコードのみが実行されることを保証し、それによりプログラムの完全性とセキュリティを保護します。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 中国語版
中国語版、とても使いやすい

WebStorm Mac版
便利なJavaScript開発ツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ホットトピック









