Uploaded image for project: 'Pluto'
  1. Pluto
  2. PLUTO-664

TCK: Contesting V2RequestTests_ClientDataRequest_ApiAction_getReader2 and _getPortletInputStream2

Details

    • Bug
    • Status: Closed
    • Major
    • Resolution: Fixed
    • 3.0.0
    • 3.0.1
    • tck
    • None

    Description

      Steps to reproduce:

      1) deploy the tck V2RequestTests war
      2) run Pluto in a debugger
      3) set a break point in the processAction method for the V2RequestTests_ClientDataRequest_ApiAction_getPortletInputStream2 test case to see which method throws the exception (line 132 in master as of this post)
      4) run the V2RequestTests_ClientDataRequest_ApiAction_getPortletInputStream2 test
      5) step over each method call to see which one throws the IllegalStateException

      Expected results:
      - getPortletInputStream should be the method that throws an IllegalStateException and the test should pass for that reason on Pluto.
      - the first call to getReader throws an IllegalStateException causing the test to pass on Pluto for the wrong reason.

      Also, if you look at the V2RequestTests_ClientDataRequest_ApiAction_getReader2 test case in the processAction method, it should call getPortletInputStream first, and then call getReader second, and only then throw an IllegalStateException, but there is no call to getReader at all in the test see lines 249 thru 264 as of this post

      Yet, the V2RequestTests_ClientDataRequest_ApiAction_getReader2 also passes on Pluto when it throws an IllegalStateException after simply calling getPortletInputStream, again never calling getReader as it should.

      The main issue with both of these tests is that an IllegalStateException will always be thrown by either getReader or getPortletInputStream when the enctype of the submitted form is application/x-www-form-urlencoded, which is the default for tests in the TCK as of now.

      Please look for my suggested fix for these tests below.

      Attachments

        Activity

          vsingleton Vernon Singleton added a comment - - edited

          This pull request was tested again master (0efe709):
          https://github.com/apache/portals-pluto/pull/20

          This PR addresses three basic things to fix the two tests:
          1) gives the TestButton class the ability to set an enctype attribute on the form.
          2) changes the render method for the two tests to setEncType("text/plain").
          3) fix the tests to pass only when the proper method throws the IllegalStateException.

          vsingleton Vernon Singleton added a comment - - edited This pull request was tested again master (0efe709): https://github.com/apache/portals-pluto/pull/20 This PR addresses three basic things to fix the two tests: 1) gives the TestButton class the ability to set an enctype attribute on the form. 2) changes the render method for the two tests to setEncType("text/plain"). 3) fix the tests to pass only when the proper method throws the IllegalStateException.
          asfgriff Neil Griffin added a comment - - edited
          asfgriff Neil Griffin added a comment - - edited Fixed in commit d4ab596f49c6269945eb425c374dd86c44f5a39e .

          People

            ngriffin7a Neil Griffin (Inactive)
            vsingleton Vernon Singleton
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

            Dates

              Created:
              Updated:
              Resolved: