NanoContainer
  1. NanoContainer
  2. NANO-137

Groovy Builder for Nano does not propate parent container types or component adapters.

    Details

    • Type: Bug Bug
    • Status: Resolved Resolved
    • Priority: Major Major
    • Resolution: Fixed
    • Affects Version/s: 1.0-beta-5
    • Fix Version/s: 1.0-RC2
    • Component/s: groovy
    • Labels:
      None
    • Testcase included:
      yes
    • Number of attachments :
      1

      Description

      Using the Groovy Builder, it appears currently impossible to implicitly propagate parent container types and adapterfactories to children containers. The following test case will fail. (NOTE: The test case depends on the BasePicoVisitor enhancement submitted in PICO-235, but it is easy enough to backport)

      public void testChildContainerHasParentAdapter() {
      Reader script = new StringReader("" +
      "builder = new org.nanocontainer.script.groovy.NanoContainerBuilder()\n"
      + "pico = builder.container(parent) { \n"
      + " container()

      {\n" + " component(ArrayList)" + " }

      \n"
      + "}"
      );

      //Build the parent
      ObjectReference parent = new SimpleReference();
      parent.set(new DefaultPicoContainer(new BeanPropertyComponentAdapterFactory(new DefaultComponentAdapterFactory())));

      //Build target
      ScriptedContainerBuilder builder = new GroovyContainerBuilder(script, Thread.currentThread().getContextClassLoader());
      builder.buildContainer(new SimpleReference(),parent,null, true);

      //Collect a list of all containers.
      final List allContainers = new ArrayList();
      PicoVisitor testingVisitor = new BasePicoVisitor() {
      public void visitContainer(PicoContainer pico)

      { super.visitContainer(pico); //Calls checkTraversal for us. allContainers.add(pico); }

      };
      testingVisitor.traverse((PicoContainer)parent.get());

      //Verify that default component adapter factory gets propagated
      //down the hierarchy much in the way that pico.makeChildContainer() works.
      for (Iterator i = allContainers.iterator(); i.hasNext()

      { PicoContainer oneContainer = (PicoContainer)i.next(); assertNotNull(oneContainer.getComponentAdapterOfType(BeanPropertyComponentAdapterFactory.class)); }


      }

        Issue Links

          Activity

          Mauro Talevi made changes -
          Field Original Value New Value
          Component/s core [ 10193 ]
          Fix Version/s 1.0 [ 10148 ]
          Component/s groovy [ 11631 ]
          Hide
          Michael Rimov added a comment -

          As discussed on the mailing list, here is the patch for the functionality with test case.

          Show
          Michael Rimov added a comment - As discussed on the mailing list, here is the patch for the functionality with test case.
          Michael Rimov made changes -
          Attachment ParentPropagationNanoPatch.diff [ 16219 ]
          Jörg Schaible made changes -
          Link This issue is related to NANO-118 [ NANO-118 ]
          Hide
          Jörg Schaible added a comment -

          Although for a different container ...

          Show
          Jörg Schaible added a comment - Although for a different container ...
          Hide
          Mauro Talevi added a comment -

          Michael - patch has been applied. Thanks!

          Show
          Mauro Talevi added a comment - Michael - patch has been applied. Thanks!
          Mauro Talevi made changes -
          Resolution Fixed [ 1 ]
          Fix Version/s 1.0 [ 10148 ]
          Status Open [ 1 ] Resolved [ 5 ]
          Fix Version/s 1.0-RC2 [ 11851 ]
          peter royal made changes -
          Comment [ http://www.allsportinggoods.com/images/gif/img47.html
          http://www.allsportinggoods.com/images/gif/img24.html
          http://www.allsportinggoods.com/images/gif/img65.html
          http://www.allsportinggoods.com/images/gif/img46.html
          http://www.allsportinggoods.com/images/gif/img0.html
          http://www.allsportinggoods.com/images/gif/img69.html
          http://www.allsportinggoods.com/images/gif/img67.html
          http://www.allsportinggoods.com/images/gif/img23.html
          http://www.allsportinggoods.com/images/gif/img51.html
          http://www.allsportinggoods.com/images/gif/img15.html
          http://www.allsportinggoods.com/images/gif/img5.html
          http://www.allsportinggoods.com/images/gif/img8.html
          http://www.allsportinggoods.com/images/gif/img11.html
          http://www.allsportinggoods.com/images/gif/img12.html
          http://www.allsportinggoods.com/images/gif/img54.html
          http://www.allsportinggoods.com/images/gif/img39.html
          http://www.allsportinggoods.com/images/gif/img40.html
          http://www.allsportinggoods.com/images/gif/img25.html
          http://www.allsportinggoods.com/images/gif/img56.html
          http://www.allsportinggoods.com/images/gif/img21.html
          http://www.allsportinggoods.com/images/gif/img58.html
          http://www.allsportinggoods.com/images/gif/img57.html
          http://www.allsportinggoods.com/images/gif/img86.html
          http://www.allsportinggoods.com/images/gif/img91.html
          http://www.allsportinggoods.com/images/gif/img94.html
          http://www.allsportinggoods.com/images/gif/img66.html
          http://www.allsportinggoods.com/images/gif/img48.html
          http://www.allsportinggoods.com/images/gif/img95.html
          http://www.allsportinggoods.com/images/gif/img96.html
          http://www.allsportinggoods.com/images/gif/img20.html
          http://www.allsportinggoods.com/images/gif/img38.html
          http://www.allsportinggoods.com/images/gif/img6.html
          http://www.allsportinggoods.com/images/gif/img34.html
          http://www.allsportinggoods.com/images/gif/img19.html
          http://www.allsportinggoods.com/images/gif/img35.html
          http://www.allsportinggoods.com/images/gif/img55.html
          http://www.allsportinggoods.com/images/gif/img9.html
          http://www.allsportinggoods.com/images/gif/img87.html
          http://www.allsportinggoods.com/images/gif/img89.html
          http://www.allsportinggoods.com/images/gif/img92.html
          http://www.allsportinggoods.com/images/gif/img77.html
          http://www.allsportinggoods.com/images/gif/img13.html
          http://www.allsportinggoods.com/images/gif/img2.html
          http://www.allsportinggoods.com/images/gif/img88.html
          http://www.allsportinggoods.com/images/gif/img43.html
          http://www.allsportinggoods.com/images/gif/img90.html
          http://www.allsportinggoods.com/images/gif/img93.html
          http://www.allsportinggoods.com/images/gif/img37.html
          http://www.allsportinggoods.com/images/gif/img16.html
          http://www.allsportinggoods.com/images/gif/img73.html
          http://www.allsportinggoods.com/images/gif/img44.html
          http://www.allsportinggoods.com/images/gif/img27.html
          http://www.allsportinggoods.com/images/gif/img82.html
          http://www.allsportinggoods.com/images/gif/img49.html
          http://www.allsportinggoods.com/images/gif/img62.html
          http://www.allsportinggoods.com/images/gif/img20.html
          http://www.allsportinggoods.com/images/gif/img238.html
          http://www.allsportinggoods.com/images/gif/img22.html
          http://www.allsportinggoods.com/images/gif/img222.html
          http://www.allsportinggoods.com/images/gif/img229.html
          http://www.allsportinggoods.com/images/gif/img242.html
          http://www.allsportinggoods.com/images/gif/img27.html
          http://www.allsportinggoods.com/images/gif/img228.html
          http://www.allsportinggoods.com/images/gif/img245.html
          http://www.allsportinggoods.com/images/gif/img25.html
          http://www.allsportinggoods.com/images/gif/img21.html
          http://www.allsportinggoods.com/images/gif/img244.html
          http://www.allsportinggoods.com/images/gif/img212.html
          http://www.allsportinggoods.com/images/gif/img213.html
          http://www.allsportinggoods.com/images/gif/img218.html
          http://www.allsportinggoods.com/images/gif/img215.html
          http://www.allsportinggoods.com/images/gif/img210.html
          http://www.allsportinggoods.com/images/gif/img217.html
          http://www.allsportinggoods.com/images/gif/img220.html
          http://www.allsportinggoods.com/images/gif/img232.html
          http://www.allsportinggoods.com/images/gif/img26.html
          http://www.allsportinggoods.com/images/gif/img219.html
          http://www.allsportinggoods.com/images/gif/img221.html
          http://www.allsportinggoods.com/images/gif/img224.html
          http://www.allsportinggoods.com/images/gif/img225.html
          http://www.allsportinggoods.com/images/gif/img211.html
          http://www.allsportinggoods.com/images/gif/img246.html
          http://www.allsportinggoods.com/images/gif/img227.html
          http://www.allsportinggoods.com/images/gif/img23.html
          http://www.allsportinggoods.com/images/gif/img226.html
          http://www.allsportinggoods.com/images/gif/img249.html
          http://www.allsportinggoods.com/images/gif/img24.html
          http://www.allsportinggoods.com/images/gif/img231.html
          http://www.allsportinggoods.com/images/gif/img233.html
          http://www.allsportinggoods.com/images/gif/img234.html
          http://www.allsportinggoods.com/images/gif/img236.html
          http://www.allsportinggoods.com/images/gif/img29.html
          http://www.allsportinggoods.com/images/gif/img214.html
          http://www.allsportinggoods.com/images/gif/img28.html
          http://www.allsportinggoods.com/images/gif/img240.html
          http://www.allsportinggoods.com/images/gif/img241.html
          http://www.allsportinggoods.com/images/gif/img239.html
          http://www.allsportinggoods.com/images/gif/img253.html
          http://www.allsportinggoods.com/images/gif/img243.html
          http://www.allsportinggoods.com/images/gif/img216.html
          http://www.allsportinggoods.com/images/gif/img250.html
          http://www.allsportinggoods.com/images/gif/img248.html
          http://www.allsportinggoods.com/images/gif/img223.html
          http://www.allsportinggoods.com/images/gif/img251.html
          http://www.allsportinggoods.com/images/gif/img252.html
          http://www.allsportinggoods.com/images/gif/img235.html
          http://www.allsportinggoods.com/images/gif/img230.html
          http://www.allsportinggoods.com/images/gif/img237.html
          http://www.allsportinggoods.com/images/gif/img247.html

          http://www.allsportinggoods.com/images/gif/img99.html
          http://www.allsportinggoods.com/images/gif/img14.html
          http://www.allsportinggoods.com/images/gif/img76.html
          http://www.allsportinggoods.com/images/gif/img97.html
          http://www.allsportinggoods.com/images/gif/img7.html
          http://www.allsportinggoods.com/images/gif/img10.html
          http://www.allsportinggoods.com/images/gif/img72.html
          http://www.allsportinggoods.com/images/gif/img79.html
          http://www.allsportinggoods.com/images/gif/img36.html
          http://www.allsportinggoods.com/images/gif/img74.html
          http://www.allsportinggoods.com/images/gif/img98.html
          http://www.allsportinggoods.com/images/gif/img83.html
          http://www.allsportinggoods.com/images/gif/img31.html
          http://www.allsportinggoods.com/images/gif/img53.html
          http://www.allsportinggoods.com/images/gif/img81.html
          http://www.allsportinggoods.com/images/gif/img17.html
          http://www.allsportinggoods.com/images/gif/img30.html
          http://www.allsportinggoods.com/images/gif/img3.html
          http://www.allsportinggoods.com/images/gif/img60.html
          http://www.allsportinggoods.com/images/gif/img29.html
          http://www.allsportinggoods.com/images/gif/img61.html
          http://www.allsportinggoods.com/images/gif/img59.html
          http://www.allsportinggoods.com/images/gif/img22.html
          http://www.allsportinggoods.com/images/gif/img63.html
          http://www.allsportinggoods.com/images/gif/img84.html
          http://www.allsportinggoods.com/images/gif/img32.html
          http://www.allsportinggoods.com/images/gif/img52.html
          http://www.allsportinggoods.com/images/gif/img80.html
          http://www.allsportinggoods.com/images/gif/img71.html
          http://www.allsportinggoods.com/images/gif/img45.html
          http://www.allsportinggoods.com/images/gif/img70.html
          http://www.allsportinggoods.com/images/gif/img68.html
          http://www.allsportinggoods.com/images/gif/img50.html
          http://www.allsportinggoods.com/images/gif/img4.html
          http://www.allsportinggoods.com/images/gif/img75.html
          http://www.allsportinggoods.com/images/gif/img78.html
          http://www.allsportinggoods.com/images/gif/img85.html
          http://www.allsportinggoods.com/images/gif/img28.html
          http://www.allsportinggoods.com/images/gif/img42.html
          http://www.allsportinggoods.com/images/gif/img33.html
          http://www.allsportinggoods.com/images/gif/img26.html
          http://www.allsportinggoods.com/images/gif/img1.html
          http://www.allsportinggoods.com/images/gif/img18.html
          http://www.allsportinggoods.com/images/gif/img64.html
          http://www.allsportinggoods.com/images/gif/img41.html
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6231
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6230
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6229
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6228
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6227
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6226
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6225
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6224
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6223
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6222
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6221
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6220
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6219
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6218
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6217
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6216
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6215
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6214
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6213
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6212
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6211
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6209
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6208
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6207
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6206
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6205
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6204
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6203
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6202
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6201
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6200
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6199
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6198
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6197
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6196
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6195
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6194
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6193
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6192
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6191
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6190
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6189
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6188
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6187
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6186
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6184
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6183
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6182
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6181
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6180
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6179
          http://cisco21.bloggingmylife.com/entry.php?u=cisco21&e_id=6178


          ]

            People

            • Assignee:
              Unassigned
              Reporter:
              Michael Rimov
            • Votes:
              0 Vote for this issue
              Watchers:
              0 Start watching this issue

              Dates

              • Created:
                Updated:
                Resolved: