Run tests for library project with different dependency sets





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







1















Environment:




  • Java 8

  • Gradle 4

  • JUnit 5


I have a library project that supports multiple setups / optional dependencies.



The library always requires Spring Boot + grpc-java.
However the user of the lib can decide whether he wants to use either netty or netty-shaded.
And finally the lib adds additional features if Spring-Security and/or Spring-Cloud are present.



I have a set of tests that runs with the default setup (netty + Spring-Security).
How do I test that I can also use all features from the library with the other setup combinations, without copying my tests multiple times?



(During the last update I used a class from the wrong lib in one of the library classes and thus the library didn't work correctly if the optional dependency was missing. Now I want to prevent similar issues in the future)



Possible solutions




  • Create a test lib project that contains the test code and create multiple test projects that execute the tests from that lib.


Not all tests work for all setups. (A security test will obviously fail if no security lib is present).
Unfortunately the number of test projects can easily explode. Currently ~8 projects are needed to test all possible combinations. If I add another optional dependency (which I consider to do) this will increase to 16.
If there is nothing easier way, I probably use this one.




  • Copy the dependencies to a specific folder and use some code to add them to the classloader dynamically.


This requires extra coding and some bad classloader magic and possibly a forked test execution mode, that does not execute the tests in parallel (because they might have to bind a port)



TLDR: Is there an easy way to run JUnit 5 Tests with different dependency sets using gradle?










share|improve this question





























    1















    Environment:




    • Java 8

    • Gradle 4

    • JUnit 5


    I have a library project that supports multiple setups / optional dependencies.



    The library always requires Spring Boot + grpc-java.
    However the user of the lib can decide whether he wants to use either netty or netty-shaded.
    And finally the lib adds additional features if Spring-Security and/or Spring-Cloud are present.



    I have a set of tests that runs with the default setup (netty + Spring-Security).
    How do I test that I can also use all features from the library with the other setup combinations, without copying my tests multiple times?



    (During the last update I used a class from the wrong lib in one of the library classes and thus the library didn't work correctly if the optional dependency was missing. Now I want to prevent similar issues in the future)



    Possible solutions




    • Create a test lib project that contains the test code and create multiple test projects that execute the tests from that lib.


    Not all tests work for all setups. (A security test will obviously fail if no security lib is present).
    Unfortunately the number of test projects can easily explode. Currently ~8 projects are needed to test all possible combinations. If I add another optional dependency (which I consider to do) this will increase to 16.
    If there is nothing easier way, I probably use this one.




    • Copy the dependencies to a specific folder and use some code to add them to the classloader dynamically.


    This requires extra coding and some bad classloader magic and possibly a forked test execution mode, that does not execute the tests in parallel (because they might have to bind a port)



    TLDR: Is there an easy way to run JUnit 5 Tests with different dependency sets using gradle?










    share|improve this question

























      1












      1








      1


      1






      Environment:




      • Java 8

      • Gradle 4

      • JUnit 5


      I have a library project that supports multiple setups / optional dependencies.



      The library always requires Spring Boot + grpc-java.
      However the user of the lib can decide whether he wants to use either netty or netty-shaded.
      And finally the lib adds additional features if Spring-Security and/or Spring-Cloud are present.



      I have a set of tests that runs with the default setup (netty + Spring-Security).
      How do I test that I can also use all features from the library with the other setup combinations, without copying my tests multiple times?



      (During the last update I used a class from the wrong lib in one of the library classes and thus the library didn't work correctly if the optional dependency was missing. Now I want to prevent similar issues in the future)



      Possible solutions




      • Create a test lib project that contains the test code and create multiple test projects that execute the tests from that lib.


      Not all tests work for all setups. (A security test will obviously fail if no security lib is present).
      Unfortunately the number of test projects can easily explode. Currently ~8 projects are needed to test all possible combinations. If I add another optional dependency (which I consider to do) this will increase to 16.
      If there is nothing easier way, I probably use this one.




      • Copy the dependencies to a specific folder and use some code to add them to the classloader dynamically.


      This requires extra coding and some bad classloader magic and possibly a forked test execution mode, that does not execute the tests in parallel (because they might have to bind a port)



      TLDR: Is there an easy way to run JUnit 5 Tests with different dependency sets using gradle?










      share|improve this question














      Environment:




      • Java 8

      • Gradle 4

      • JUnit 5


      I have a library project that supports multiple setups / optional dependencies.



      The library always requires Spring Boot + grpc-java.
      However the user of the lib can decide whether he wants to use either netty or netty-shaded.
      And finally the lib adds additional features if Spring-Security and/or Spring-Cloud are present.



      I have a set of tests that runs with the default setup (netty + Spring-Security).
      How do I test that I can also use all features from the library with the other setup combinations, without copying my tests multiple times?



      (During the last update I used a class from the wrong lib in one of the library classes and thus the library didn't work correctly if the optional dependency was missing. Now I want to prevent similar issues in the future)



      Possible solutions




      • Create a test lib project that contains the test code and create multiple test projects that execute the tests from that lib.


      Not all tests work for all setups. (A security test will obviously fail if no security lib is present).
      Unfortunately the number of test projects can easily explode. Currently ~8 projects are needed to test all possible combinations. If I add another optional dependency (which I consider to do) this will increase to 16.
      If there is nothing easier way, I probably use this one.




      • Copy the dependencies to a specific folder and use some code to add them to the classloader dynamically.


      This requires extra coding and some bad classloader magic and possibly a forked test execution mode, that does not execute the tests in parallel (because they might have to bind a port)



      TLDR: Is there an easy way to run JUnit 5 Tests with different dependency sets using gradle?







      java spring gradle junit dependencies






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 23 '18 at 15:20









      ST-DDTST-DDT

      72911525




      72911525
























          0






          active

          oldest

          votes












          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53449197%2frun-tests-for-library-project-with-different-dependency-sets%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53449197%2frun-tests-for-library-project-with-different-dependency-sets%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          "Incorrect syntax near the keyword 'ON'. (on update cascade, on delete cascade,)

          Alcedinidae

          Origin of the phrase “under your belt”?