/*
* Copyright (c) 2011 NTT DATA Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package jp.terasoluna.fw.batch.message;
import static org.junit.Assert.*;
import java.util.List;
import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.MessageSourceResolvable;
import org.springframework.context.NoSuchMessageException;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.validation.BindException;
import org.springframework.validation.Errors;
import org.springframework.validation.FieldError;
import org.springframework.validation.ValidationUtils;
import jp.terasoluna.fw.util.PropertyUtil;
/**
* 事前条件<br>
* <br>
* ・src/test/resourcesフォルダ配下にAppricationResources.propertiesが存在すること。<br>
* ・src/test/resources/apppropsフォルダ配下にbatch.propertiesが存在すること。<br>
* <br>
* ・batch.propertiesにプロパティmessageAccessor.defaultの値が設定されていること。<br>
* <fieldset><legend>batch.properties設定例</legend> #メッセージソースアクセサのBean名<br>
* messageAccessor.default=msgAcc </fieldset> <br>
* ・Bean定義ファイルにプロパティで設定された値のBean名が設定されていること。<br>
* <fieldset><legend>AdminContext.xml設定例</legend> <!-- メッセージアクセサ --><br>
* <bean id="msgAcc" class="jp.terasoluna.fw.batch.message.MessageAccessorImpl" /> </fieldset> <br>
* ・messages.propertiesファイルが存在すること<br>
*/
public class MessageAccessorImplTest {
/**
* プロパティ値取得値
*/
private String value = null;
/**
* コンテナ用のフィールド
*/
private ApplicationContext context;
/**
* MessageAccessorクラスのフィールド
*/
private MessageAccessor messageAccessor;
@Before
public void setUp() {
// メッセージソースアクセサのBean名取得
context = new ClassPathXmlApplicationContext(
"beansDef/AdminContext.xml");
value = PropertyUtil.getProperty("messageAccessor.default");
messageAccessor = (MessageAccessor) context.getBean(value,
MessageAccessor.class);
}
/**
* testGetMessage01()<br>
* <br>
* 事前状態:errors.alphaNumericStringが設定されていること<br>
* <br>
* テスト概要:パラメータを1つ持つメッセージキーに該当するメッセージを正常に取得することができることを確認する<br>
* <br>
* 確認項目:プロパティに設定したメッセージが取得されていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage01() throws Exception {
String[] args = { "test1" };
String result = messageAccessor.getMessage("errors.alphaNumericString",
args);
assertEquals("test1には半角英数字で入力してください.", result);
}
/**
* testGetMessage02()<br>
* <br>
* 事前状態:errors.alphaNumericStringが設定されていること<br>
* <br>
* テスト概要:パラメータにnullを設定し、 メッセージキーに該当するメッセージを取得したときパラメータが変換されずにメッセージが返却されることを確認する<br>
* <br>
* 確認項目:プロパティに設定したメッセージが取得されていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage02() throws Exception {
String result = messageAccessor.getMessage("errors.alphaNumericString",
null);
assertEquals("{0}には半角英数字で入力してください.", result);
}
/**
* testGetMessage03()<br>
* <br>
* テスト概要:存在しないメッセージキーの場合、NoSuchMessageExceptionがスローされることを確認する<br>
* <br>
* 確認項目:NoSuchMessageExceptionがスローされていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage03() throws Exception {
try {
messageAccessor.getMessage("test", null);
fail();
} catch (NoSuchMessageException e) {
// 何もしない
}
}
/**
* testGetMessage04()<br>
* <br>
* テスト概要:メッセージキーに空文字を設定した場合、NoSuchMessageExceptionがスローされることを確認する<br>
* <br>
* 確認項目:NoSuchMessageExceptionがスローされていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage04() throws Exception {
try {
messageAccessor.getMessage("", null);
fail();
} catch (NoSuchMessageException e) {
// 何もしない
}
}
/**
* testGetMessage05()<br>
* <br>
* テスト概要:メッセージキーにnullを設定した場合、NoSuchMessageExceptionがスローされることを確認する<br>
* <br>
* 確認項目:NoSuchMessageExceptionがスローされていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage05() throws Exception {
try {
messageAccessor.getMessage(null, null);
fail();
} catch (NoSuchMessageException e) {
// 何もしない
}
}
/**
* testGetMessage06()<br>
* <br>
* テスト概要:MessageResolvableにnullを設定した場合、NullPointerExceptionがスローされることを確認する<br>
* <br>
* 確認項目:NullPointerExceptionがスローされていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage06() throws Exception {
MessageSourceResolvable resolvable = null;
try {
messageAccessor.getMessage(resolvable);
fail("NullPointerExceptionが発生しませんでした。");
} catch (NullPointerException e) {
// 何もしない
}
}
/**
* testGetMessage07()<br>
* <br>
* テスト概要:MessageResolvableを使用してメッセージを解決できることを確認する<br>
* コードが見つからない場合はデフォルトメッセージとなる<br>
* <br>
* 確認項目:デフォルトメッセージが出力されていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage07() throws Exception {
// ダミーBeanの項目にnullを設定する
ValidationTargetDummyBean validationTargetDummy = new ValidationTargetDummyBean();
validationTargetDummy.setHoge(null);
// ValidationUtilsを使用してnullを設定した項目の入力チェックを行い、
// FieldErrorオブジェクトを作成する
Errors errors = new BindException(validationTargetDummy, "dummy");
ValidationUtils.rejectIfEmpty(errors, "hoge", "errors.noKey",
new Object[] { "テスト" }, "デフォルトメッセージです");
List<FieldError> fieldErrors = errors.getFieldErrors();
assertEquals(1, fieldErrors.size());
// MessageAccessorを使用して出力されるメッセージが妥当であることを確認する
String result = messageAccessor.getMessage(fieldErrors.get(0));
assertEquals("デフォルトメッセージです", result);
}
/**
* testGetMessage08()<br>
* <br>
* テスト概要:MessageResolvableを使用してメッセージを解決できることを確認する<br>
* <br>
* 確認項目:プロパティに設定したメッセージが出力されていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage08() throws Exception {
// ダミーBeanの項目にnullを設定する
ValidationTargetDummyBean validationTargetDummy = new ValidationTargetDummyBean();
validationTargetDummy.setHoge(null);
// ValidationUtilsを使用してnullを設定した項目の入力チェックを行い、
// FieldErrorオブジェクトを作成する
Errors errors = new BindException(validationTargetDummy, "dummy");
ValidationUtils.rejectIfEmpty(errors, "hoge", "errors.required",
new Object[] { "テスト" }, "デフォルトメッセージです");
List<FieldError> fieldErrors = errors.getFieldErrors();
assertEquals(1, fieldErrors.size());
// MessageAccessorを使用して出力されるメッセージが妥当であることを確認する
String result = messageAccessor.getMessage(fieldErrors.get(0));
assertEquals("テストは入力必須項目です.", result);
}
/**
* testGetMessage09()<br>
* <br>
* テスト概要:デフォルトメッセージが設定されていないMessageResolvableを使用してメッセージが見つからない場合、 NoSuchMessageExceptionがスローされる<br>
* <br>
* 確認項目:NoSuchMessageExceptionがスローされていることを確認する<br>
* <br>
* @throws Exception
*/
@Test
public void testGetMessage09() throws Exception {
// ダミーBeanの項目にnullを設定する
ValidationTargetDummyBean validationTargetDummy = new ValidationTargetDummyBean();
validationTargetDummy.setHoge(null);
// ValidationUtilsを使用してnullを設定した項目の入力チェックを行い、
// デフォルトメッセージを設定していないFieldErrorオブジェクトを作成する
Errors errors = new BindException(validationTargetDummy, "dummy");
ValidationUtils.rejectIfEmpty(errors, "hoge", "errors.noKey",
new Object[] { "テスト" });
List<FieldError> fieldErrors = errors.getFieldErrors();
assertEquals(1, fieldErrors.size());
try {
messageAccessor.getMessage(fieldErrors.get(0));
fail("NoSuchMessageExceptionが発生しませんでした。");
} catch (NoSuchMessageException e) {
// 何もしない
}
}
// MessageResolvableを使用したMessageAccessorImplのテストにおいて
// ValidationUtilsを使用するためのダミーBean
class ValidationTargetDummyBean {
private String hoge;
public String getHoge() {
return hoge;
}
public void setHoge(String hoge) {
this.hoge = hoge;
}
}
}