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.

YieldTest.java 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. /*
  2. * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
  3. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  4. *
  5. * This code is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License version 2 only, as
  7. * published by the Free Software Foundation.
  8. *
  9. * This code is distributed in the hope that it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  12. * version 2 for more details (a copy is included in the LICENSE file that
  13. * accompanied this code).
  14. *
  15. * You should have received a copy of the GNU General Public License version
  16. * 2 along with this work; if not, write to the Free Software Foundation,
  17. * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18. *
  19. * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20. * or visit www.oracle.com if you need additional information or have any
  21. * questions.
  22. *
  23. */
  24. package com.github.dcevm.test.fields;
  25. import org.junit.Before;
  26. import org.junit.Test;
  27. import java.util.ArrayList;
  28. import java.util.Arrays;
  29. import java.util.List;
  30. import static com.github.dcevm.test.util.HotSwapTestHelper.__toVersion__;
  31. import static com.github.dcevm.test.util.HotSwapTestHelper.__version__;
  32. import static org.junit.Assert.assertEquals;
  33. /**
  34. * Test case that produces a list of integer values recursively.
  35. * The recursive function does not contain a conditional statement.
  36. * The recursion is stopped by swapping the recursive method with a different non-recursive implementation.
  37. *
  38. * @author Thomas Wuerthinger
  39. */
  40. public class YieldTest {
  41. // Version 0
  42. public static class Base {
  43. protected List<Integer> arr = new ArrayList<Integer>();
  44. public void reset() {
  45. __toVersion__(0);
  46. }
  47. public void next() {
  48. __toVersion__(__version__() + 1);
  49. }
  50. }
  51. public static abstract class A extends Base {
  52. public List<Integer> gen() {
  53. arr.add(produce());
  54. next();
  55. return gen();
  56. }
  57. public abstract int produce();
  58. }
  59. public static class B extends A {
  60. @Override
  61. public int produce() {
  62. return 1;
  63. }
  64. }
  65. public static class B___10 extends A {
  66. @Override
  67. public int produce() {
  68. return 2;
  69. }
  70. }
  71. public static class B___20 extends A {
  72. private int x;
  73. @Override
  74. public int produce() {
  75. return ++x;
  76. }
  77. }
  78. public static class A___30 extends Base {
  79. public List<Integer> gen() {
  80. reset();
  81. return arr;
  82. }
  83. }
  84. @Before
  85. public void setUp() throws Exception {
  86. __toVersion__(0);
  87. }
  88. @Test
  89. public void testYield() {
  90. assert __version__() == 0;
  91. B b = new B();
  92. assertEquals(Arrays.asList(
  93. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  94. 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
  95. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10), b.gen());
  96. assert __version__() == 0;
  97. }
  98. }