You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DataSourceBoVTest.java 5.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /*
  2. * Copyright 2000-2016 Vaadin Ltd.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  5. * use this file except in compliance with the License. You may obtain a copy of
  6. * the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  12. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  13. * License for the specific language governing permissions and limitations under
  14. * the License.
  15. */
  16. package com.vaadin.server.data.datasource.bov;
  17. import java.util.ArrayList;
  18. import java.util.Arrays;
  19. import java.util.Collection;
  20. import java.util.List;
  21. import java.util.stream.Collectors;
  22. import java.util.stream.Stream;
  23. import org.junit.Before;
  24. import org.junit.Test;
  25. import com.vaadin.server.data.BackEndDataSource;
  26. import com.vaadin.server.data.DataSource;
  27. import com.vaadin.server.data.SortOrder;
  28. import com.vaadin.shared.data.sort.SortDirection;
  29. /**
  30. * Vaadin 8 Example from Book of Vaadin
  31. *
  32. * @author Vaadin Ltd
  33. */
  34. public class DataSourceBoVTest {
  35. private PersonServiceImpl personService;
  36. public static class PersonServiceImpl implements PersonService {
  37. final Person[] persons;
  38. public PersonServiceImpl(Person... persons) {
  39. this.persons = persons;
  40. }
  41. @Override
  42. public List<Person> fetchPersons(int offset, int limit) {
  43. return Arrays.stream(persons).skip(offset).limit(limit)
  44. .collect(Collectors.toList());
  45. }
  46. @Override
  47. public List<Person> fetchPersons(int offset, int limit,
  48. Collection<PersonSort> personSorts) {
  49. Stream<Person> personStream = Arrays.stream(persons).skip(offset)
  50. .limit(limit);
  51. if (personSorts != null)
  52. for (PersonSort personSort : personSorts) {
  53. personStream = personStream.sorted(personSort);
  54. }
  55. return personStream.collect(Collectors.toList());
  56. }
  57. @Override
  58. public int getPersonCount() {
  59. return persons.length;
  60. }
  61. @Override
  62. public PersonSort createSort(String propertyName, boolean descending) {
  63. PersonSort result;
  64. switch (propertyName) {
  65. case "name":
  66. result = (person1, person2) -> String.CASE_INSENSITIVE_ORDER
  67. .compare(person1.getName(), person2.getName());
  68. break;
  69. case "born":
  70. result = (person1, person2) -> person2.getBorn()
  71. - person1.getBorn();
  72. break;
  73. default:
  74. throw new IllegalArgumentException(
  75. "wrong field name " + propertyName);
  76. }
  77. if (descending)
  78. return (person1, person2) -> result.compare(person2, person1);
  79. else
  80. return result;
  81. }
  82. }
  83. @Test
  84. public void testPersons() {
  85. DataSource<Person> dataSource = createUnsortedDatasource();
  86. // TODO test if the datasource contains all defined Persons in
  87. // correct(unchanged) order
  88. }
  89. private DataSource<Person> createUnsortedDatasource() {
  90. DataSource<Person> dataSource = new BackEndDataSource<>(
  91. // First callback fetches items based on a query
  92. query -> {
  93. // The index of the first item to load
  94. int offset = query.getOffset();
  95. // The number of items to load
  96. int limit = query.getLimit();
  97. List<Person> persons = getPersonService()
  98. .fetchPersons(offset, limit);
  99. return persons.stream();
  100. },
  101. // Second callback fetches the number of items for a query
  102. query -> getPersonService().getPersonCount());
  103. return dataSource;
  104. }
  105. @Test
  106. public void testSortedPersons() {
  107. DataSource<Person> dataSource = createSortedDataSource();
  108. // TODO test if datasource contains all defined Persons in correct order
  109. // TODO test Query.sortOrders correctness
  110. }
  111. private DataSource<Person> createSortedDataSource() {
  112. DataSource<Person> dataSource = new BackEndDataSource<>(
  113. // First callback fetches items based on a query
  114. query -> {
  115. List<PersonService.PersonSort> sortOrders = new ArrayList<>();
  116. for (SortOrder<String> queryOrder : query.getSortOrders()) {
  117. PersonService.PersonSort sort = personService
  118. .createSort(
  119. // The name of the sorted property
  120. queryOrder.getSorted(),
  121. // The sort direction for this property
  122. queryOrder
  123. .getDirection() == SortDirection.DESCENDING);
  124. sortOrders.add(sort);
  125. }
  126. return getPersonService().fetchPersons(query.getOffset(),
  127. query.getLimit(), sortOrders).stream();
  128. },
  129. // Second callback fetches the number of items for a query
  130. query -> getPersonService().getPersonCount());
  131. return dataSource;
  132. }
  133. public PersonServiceImpl getPersonService() {
  134. return personService;
  135. }
  136. @Before
  137. public void buildService() {
  138. personService = new PersonServiceImpl(
  139. new Person("George Washington", 1732),
  140. new Person("John Adams", 1735),
  141. new Person("Thomas Jefferson", 1743),
  142. new Person("James Madison", 1751));
  143. }
  144. }