Skip to content

Commit

Permalink
Merge pull request #3266 from mawen12/feature-objectwrapper-test
Browse files Browse the repository at this point in the history
Add ObjectWrapper test
  • Loading branch information
hazendaz authored Oct 14, 2024
2 parents 8c1316e + 851b798 commit 46bb068
Show file tree
Hide file tree
Showing 4 changed files with 658 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,213 @@
/*
* Copyright 2009-2024 the original author or authors.
*
* 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
*
* https://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 org.apache.ibatis.reflection.wrapper;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.ibatis.domain.blog.Author;
import org.apache.ibatis.domain.misc.RichType;
import org.apache.ibatis.reflection.SystemMetaObject;
import org.apache.ibatis.reflection.property.PropertyTokenizer;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;

import static org.assertj.core.api.Assertions.*;
import static org.junit.jupiter.api.Assertions.*;

/**
* @author <a href="1181963012mw@gmail.com">mawen12</a>
* @see BeanWrapper
*/
class BeanWrapperUnitTest extends ObjectWrapperBaseTest {

private RichType richType;

private ObjectWrapper wrapper;

@BeforeEach
void setup() {
this.richType = new RichType();
this.wrapper = new BeanWrapper(SystemMetaObject.forObject(richType), richType);
}

@Test
@Override
void shouldGet() {
richType.setRichProperty("mybatis");

Object value = wrapper.get(new PropertyTokenizer("richProperty"));

assertEquals("mybatis", value);
}

@Test
void shouldGetWhichContainsDelim() {
RichType nested = new RichType();
nested.setRichProperty("mybatis");
richType.setRichType(nested);

Object value = wrapper.get(new PropertyTokenizer("richType.richProperty"));

assertEquals("mybatis", value);
}

@Test
void shouldGetWhichContainsIndex() {
richType.setRichList(Arrays.asList(1L, "abc"));
richType.setRichMap(new HashMap<String, Object>(){{
put("key1", "value1");
put("key2", "value2");
}});

assertEquals("abc", wrapper.get(new PropertyTokenizer("richList[1]")));
assertEquals("value2", wrapper.get(new PropertyTokenizer("richMap[key2]")));

}

@Test
@Override
void shouldSet() {
wrapper.set(new PropertyTokenizer("richProperty"), "mybatis");

assertEquals("mybatis", richType.getRichProperty());
}

@Test
void shouldSetWhichContainsDelim() {
wrapper.set(new PropertyTokenizer("richType.richProperty"), "mybatis");

assertEquals("mybatis", richType.getRichType().getRichProperty());
}

@Test
void shouldSetWhichContainsIndex() {
List<Object> list = Arrays.asList(1L, 2L);
richType.setRichList(list);

wrapper.set(new PropertyTokenizer("richList[0]"), "mybatis");

assertEquals("mybatis", list.get(0));
}

@Test
@Override
void shouldFindProperty() {
String property = wrapper.findProperty("richProperty", false);

assertEquals("richProperty", property);
}

@Test
void shouldFindPropertyContainsDelim() {
String property = wrapper.findProperty("richType.richProperty", false);

assertEquals("richType.richProperty", property);
}

@Test
void shouldFindPropertyContainsIndex() {
String property = wrapper.findProperty("richList[0]", false);

assertNull(property);
}

@Test
@Override
void shouldGetGetterNames() {
String[] getterNames = wrapper.getGetterNames();

assertThat(getterNames).containsExactlyInAnyOrder("richType", "richProperty", "richList", "richMap", "richField");
}

@Test
@Override
void shouldGetSetterNames() {
String[] setterNames = wrapper.getSetterNames();

assertThat(setterNames).containsExactlyInAnyOrder("richType", "richProperty", "richList", "richMap", "richField");
}

@Test
@Override
void shouldGetGetterType() {
assertEquals(RichType.class, wrapper.getGetterType("richType"));
assertEquals(String.class, wrapper.getGetterType("richField"));
assertEquals(String.class, wrapper.getGetterType("richProperty"));
assertEquals(Map.class, wrapper.getGetterType("richMap"));
assertEquals(List.class, wrapper.getGetterType("richList"));
}

@Test
@Override
void shouldGetSetterType() {
assertEquals(RichType.class, wrapper.getSetterType("richType"));
assertEquals(String.class, wrapper.getSetterType("richField"));
assertEquals(String.class, wrapper.getSetterType("richProperty"));
assertEquals(Map.class, wrapper.getSetterType("richMap"));
assertEquals(List.class, wrapper.getSetterType("richList"));
}

@Test
@Override
void shouldHasGetter() {
assertTrue(wrapper.hasGetter("richType"));
assertTrue(wrapper.hasGetter("richField"));
assertTrue(wrapper.hasGetter("richProperty"));
assertTrue(wrapper.hasGetter("richMap"));
assertTrue(wrapper.hasGetter("richList"));
}

@Test
@Override
void shouldHasSetter() {
assertTrue(wrapper.hasGetter("richType"));
assertTrue(wrapper.hasGetter("richField"));
assertTrue(wrapper.hasGetter("richProperty"));
assertTrue(wrapper.hasGetter("richMap"));
assertTrue(wrapper.hasGetter("richList"));
}

@Test
@Override
void shouldIsCollection() {
assertFalse(wrapper.isCollection());
}

@Test
@Override
void shouldInstantiatePropertyValue() {
// Nothing
}

@Test
@Override
void shouldAddElement() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.add("1"));
}

@Test
@Override
void shouldAddAll() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.addAll(new ArrayList<>()));
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,152 @@
/*
* Copyright 2009-2024 the original author or authors.
*
* 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
*
* https://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 org.apache.ibatis.reflection.wrapper;

import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import org.apache.ibatis.reflection.MetaObject;
import org.apache.ibatis.reflection.SystemMetaObject;
import org.apache.ibatis.reflection.property.PropertyTokenizer;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.mockito.Mock;
import org.mockito.junit.jupiter.MockitoExtension;

import static org.assertj.core.api.Assertions.*;
import static org.junit.jupiter.api.Assertions.*;
import static org.mockito.Mockito.*;

/**
* @author <a href="1181963012mw@gmail.com">mawen12</a>
* @see CollectionWrapper
*/
@ExtendWith(MockitoExtension.class)
class CollectionWrapperUnitTest extends ObjectWrapperBaseTest {

@Mock
private Collection<Object> collection;

@Mock
private PropertyTokenizer tokenizer;

private ObjectWrapper wrapper;

@BeforeEach
void setup() {
MetaObject metaObject = SystemMetaObject.forObject(collection);
this.wrapper = new CollectionWrapper(metaObject, collection);
}

@Test
@Override
void shouldGet() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.get(tokenizer));
}

@Test
@Override
void shouldSet() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.set(tokenizer, null));
}

@Test
@Override
void shouldFindProperty() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.findProperty("abc", true));
}

@Test
@Override
void shouldGetGetterNames() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.getGetterNames());
}

@Test
@Override
void shouldGetSetterNames() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.getSetterNames());
}

@Test
@Override
void shouldGetGetterType() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.getGetterType("abc"));
}

@Test
@Override
void shouldGetSetterType() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.getSetterType("abc"));
}

@Test
@Override
void shouldHasGetter() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.hasGetter("abc"));
}

@Test
@Override
void shouldHasSetter() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.hasSetter("abc"));
}

@Test
@Override
void shouldIsCollection() {
assertTrue(wrapper.isCollection());
}

@Test
@Override
void shouldInstantiatePropertyValue() {
assertThatExceptionOfType(UnsupportedOperationException.class)
.isThrownBy(() -> wrapper.instantiatePropertyValue("abc", tokenizer, null));
}

@Test
@Override
void shouldAddElement() {
wrapper.add("bdc");

verify(collection).add("bdc");
}

@Test
@Override
void shouldAddAll() {
List<Object> list = new ArrayList<>() {{
add("1");
add("2");
add("3");
}};
wrapper.addAll(list);

verify(collection).addAll(list);
}
}
Loading

0 comments on commit 46bb068

Please sign in to comment.