You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@jclouds.apache.org by na...@apache.org on 2013/09/04 10:41:06 UTC

[1/2] git commit: JCLOUDS-256: Add missing API to list environment recipes

Updated Branches:
  refs/heads/master 3f2a196f2 -> eecfbf016


JCLOUDS-256: Add missing API to list environment recipes


Project: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/repo
Commit: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/commit/83f4081a
Tree: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/tree/83f4081a
Diff: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/diff/83f4081a

Branch: refs/heads/master
Commit: 83f4081a02fda257f9209cb1b697fcd1242c9dce
Parents: 3f2a196
Author: Noorul Islam K M <no...@noorul.com>
Authored: Tue Sep 3 16:21:33 2013 +0530
Committer: Ignasi Barrera <na...@apache.org>
Committed: Wed Sep 4 10:39:31 2013 +0200

----------------------------------------------------------------------
 .../src/main/java/org/jclouds/chef/ChefApi.java | 15 ++++
 .../org/jclouds/chef/test/TransientChefApi.java |  5 ++
 .../org/jclouds/chef/ChefApiExpectTest.java     | 95 ++++++++++++++++++++
 .../chef/internal/BaseChefApiLiveTest.java      |  6 ++
 .../src/test/resources/environment_recipes.json |  6 ++
 5 files changed, 127 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/83f4081a/core/src/main/java/org/jclouds/chef/ChefApi.java
----------------------------------------------------------------------
diff --git a/core/src/main/java/org/jclouds/chef/ChefApi.java b/core/src/main/java/org/jclouds/chef/ChefApi.java
index faa189c..9dd1df4 100644
--- a/core/src/main/java/org/jclouds/chef/ChefApi.java
+++ b/core/src/main/java/org/jclouds/chef/ChefApi.java
@@ -923,4 +923,19 @@ public interface ChefApi extends Closeable {
    @Path("/environments/{environmentname}/cookbooks/{cookbookname}?num_versions={numversions}")
    CookbookDefinition getEnvironmentCookbook(@PathParam("environmentname") String environmentname,
          @PathParam("cookbookname") String cookbookname, @PathParam("numversions") String numversions);
+  
+   /**
+    * @return List of environment recipes.
+    * @throws AuthorizationException
+    *            <p/>
+    *            "401 Unauthorized" if you are not a recognized user.
+    *            <p/>
+    *            "403 Forbidden" if you do not have rights to list environment recipes.
+    */
+   @SinceApiVersion("0.10.0")
+   @Named("environment:recipelist")
+   @GET
+   @Path("/environments/{environmentname}/recipes")
+   @Fallback(EmptySetOnNotFoundOr404.class)
+   Set<String> listEnvironmentRecipes(@PathParam("environmentname") String environmentname);
 }

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/83f4081a/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
----------------------------------------------------------------------
diff --git a/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java b/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
index 908ae2f..90919b7 100644
--- a/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
+++ b/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
@@ -373,6 +373,11 @@ public class TransientChefApi implements ChefApi {
    }
 
    @Override
+   public Set<String> listEnvironmentRecipes(String environmentname) {
+      throw new UnsupportedOperationException();
+   }
+
+   @Override
    public void close() throws IOException {
       closer.close();
    }

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/83f4081a/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
----------------------------------------------------------------------
diff --git a/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java b/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
new file mode 100644
index 0000000..fd34e2c
--- /dev/null
+++ b/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
@@ -0,0 +1,95 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.jclouds.chef;
+
+import static org.testng.Assert.assertEquals;
+import static org.testng.Assert.assertTrue;
+
+import java.util.Set;
+
+import javax.ws.rs.core.MediaType;
+
+import org.jclouds.chef.BaseChefApiExpectTest;
+import org.jclouds.chef.ChefApi;
+import org.jclouds.date.TimeStamp;
+import org.jclouds.chef.config.ChefHttpApiModule;
+import org.jclouds.http.HttpRequest;
+import org.jclouds.http.HttpResponse;
+import org.jclouds.rest.ConfiguresRestClient;
+import org.testng.annotations.Test;
+
+import com.google.common.base.Supplier;
+import com.google.inject.Module;
+
+/**
+ * Expect tests for the {@link ChefApi} class.
+ * 
+ * @author Noorul Islam K M
+ */
+@Test(groups = "unit", testName = "ChefApiExpectTest")
+public class ChefApiExpectTest extends BaseChefApiExpectTest<ChefApi> {
+   public ChefApiExpectTest() {
+     provider = "chef";
+   }
+
+   public void testListEnvironmentRecipesReturns2xx() {
+      ChefApi api = requestSendsResponse(
+            signed(HttpRequest.builder() //
+                  .method("GET") //
+                  .endpoint("http://localhost:4000/environments/dev/recipes") //
+                  .addHeader("X-Chef-Version", ChefApi.VERSION) //
+                  .addHeader("Accept", MediaType.APPLICATION_JSON).build()), //
+            HttpResponse.builder().statusCode(200)
+                  .payload(payloadFromResourceWithContentType("/environment_recipes.json", MediaType.APPLICATION_JSON)) //
+                  .build());
+      Set<String> recipes = api.listEnvironmentRecipes("dev");
+      assertEquals(recipes.size(), 3);
+      assertTrue(recipes.contains("apache2"));
+   }
+
+   public void testListEnvironmentRecipesReturns404() {
+      ChefApi api = requestSendsResponse(
+            signed(HttpRequest.builder() //
+                  .method("GET") //
+                  .endpoint("http://localhost:4000/environments/dev/recipes") //
+                  .addHeader("X-Chef-Version", ChefApi.VERSION) //
+                  .addHeader("Accept", MediaType.APPLICATION_JSON).build()), //
+            HttpResponse.builder().statusCode(404)
+                  .build());
+
+      assertTrue(api.listEnvironmentRecipes("dev").isEmpty());
+   }
+
+   @Override
+   protected Module createModule() {
+      return new TestChefRestClientModule();
+   }
+
+   @ConfiguresRestClient
+   static class TestChefRestClientModule extends ChefHttpApiModule {
+      @Override
+      protected String provideTimeStamp(@TimeStamp Supplier<String> cache) {
+         return "timestamp";
+      }
+   }
+
+   @Override
+   protected ChefApiMetadata createApiMetadata() {
+      return new ChefApiMetadata();
+   }
+   
+}

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/83f4081a/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
----------------------------------------------------------------------
diff --git a/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java b/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
index 529df68..7256323 100644
--- a/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
+++ b/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
@@ -464,6 +464,12 @@ public abstract class BaseChefApiLiveTest<A extends ChefApi> extends BaseChefLiv
       assertTrue(waitForIndex.apply(options));
    }
 
+   @Test(dependsOnMethods = "testCreateEnvironment")
+   public void testListEnvironmentRecipes() {
+      Set<String> recipeList = api.listEnvironmentRecipes(PREFIX);
+      assertTrue(!recipeList.isEmpty());
+   }
+
    @AfterClass(groups = { "live", "integration" })
    @Override
    public void tearDown() {

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/83f4081a/core/src/test/resources/environment_recipes.json
----------------------------------------------------------------------
diff --git a/core/src/test/resources/environment_recipes.json b/core/src/test/resources/environment_recipes.json
new file mode 100644
index 0000000..cca3a11
--- /dev/null
+++ b/core/src/test/resources/environment_recipes.json
@@ -0,0 +1,6 @@
+[
+  "ant",
+  "apache2",
+  "apache2::mod_auth_openid"
+]
+ 


[2/2] git commit: JCLOUDS-256: Add missing API to list environment nodes

Posted by na...@apache.org.
JCLOUDS-256: Add missing API to list environment nodes


Project: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/repo
Commit: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/commit/eecfbf01
Tree: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/tree/eecfbf01
Diff: http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/diff/eecfbf01

Branch: refs/heads/master
Commit: eecfbf016d9da9dc84b20ec51a610ef148e4dafb
Parents: 83f4081
Author: Noorul Islam K M <no...@noorul.com>
Authored: Wed Sep 4 12:45:50 2013 +0530
Committer: Ignasi Barrera <na...@apache.org>
Committed: Wed Sep 4 10:39:35 2013 +0200

----------------------------------------------------------------------
 .../src/main/java/org/jclouds/chef/ChefApi.java | 16 +++++++++++
 .../org/jclouds/chef/test/TransientChefApi.java |  5 ++++
 .../org/jclouds/chef/ChefApiExpectTest.java     | 28 ++++++++++++++++++++
 .../chef/internal/BaseChefApiLiveTest.java      | 12 +++++++++
 core/src/test/resources/environment_nodes.json  |  5 ++++
 5 files changed, 66 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/eecfbf01/core/src/main/java/org/jclouds/chef/ChefApi.java
----------------------------------------------------------------------
diff --git a/core/src/main/java/org/jclouds/chef/ChefApi.java b/core/src/main/java/org/jclouds/chef/ChefApi.java
index 9dd1df4..e319ea7 100644
--- a/core/src/main/java/org/jclouds/chef/ChefApi.java
+++ b/core/src/main/java/org/jclouds/chef/ChefApi.java
@@ -938,4 +938,20 @@ public interface ChefApi extends Closeable {
    @Path("/environments/{environmentname}/recipes")
    @Fallback(EmptySetOnNotFoundOr404.class)
    Set<String> listEnvironmentRecipes(@PathParam("environmentname") String environmentname);
+
+   /**
+    * @return List of environment nodes.
+    * @throws AuthorizationException
+    *            <p/>
+    *            "401 Unauthorized" if you are not a recognized user.
+    *            <p/>
+    *            "403 Forbidden" if you do not have rights to list environment nodes.
+    */
+   @SinceApiVersion("0.10.0")
+   @Named("environment:nodelist")
+   @GET
+   @Path("/environments/{environmentname}/nodes")
+   @ResponseParser(ParseKeySetFromJson.class)   
+   @Fallback(EmptySetOnNotFoundOr404.class)
+   Set<String> listEnvironmentNodes(@PathParam("environmentname") String environmentname);  
 }

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/eecfbf01/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
----------------------------------------------------------------------
diff --git a/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java b/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
index 90919b7..ad09275 100644
--- a/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
+++ b/core/src/main/java/org/jclouds/chef/test/TransientChefApi.java
@@ -378,6 +378,11 @@ public class TransientChefApi implements ChefApi {
    }
 
    @Override
+   public Set<String> listEnvironmentNodes(String environmentname) {
+      throw new UnsupportedOperationException();
+   }
+  
+   @Override
    public void close() throws IOException {
       closer.close();
    }

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/eecfbf01/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
----------------------------------------------------------------------
diff --git a/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java b/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
index fd34e2c..39e6e5e 100644
--- a/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
+++ b/core/src/test/java/org/jclouds/chef/ChefApiExpectTest.java
@@ -74,6 +74,34 @@ public class ChefApiExpectTest extends BaseChefApiExpectTest<ChefApi> {
       assertTrue(api.listEnvironmentRecipes("dev").isEmpty());
    }
 
+   public void testListEnvironmentNodesReturns2xx() {
+      ChefApi api = requestSendsResponse(
+            signed(HttpRequest.builder() //
+                  .method("GET") //
+                  .endpoint("http://localhost:4000/environments/dev/nodes") //
+                  .addHeader("X-Chef-Version", ChefApi.VERSION) //
+                  .addHeader("Accept", MediaType.APPLICATION_JSON).build()), //
+            HttpResponse.builder().statusCode(200)
+                  .payload(payloadFromResourceWithContentType("/environment_nodes.json", MediaType.APPLICATION_JSON)) //
+                  .build());
+      Set<String> nodes = api.listEnvironmentNodes("dev");
+      assertEquals(nodes.size(), 3);
+      assertTrue(nodes.contains("blah"));
+   }
+
+   public void testListEnvironmentNodesReturns404() {
+      ChefApi api = requestSendsResponse(
+            signed(HttpRequest.builder() //
+                  .method("GET") //
+                  .endpoint("http://localhost:4000/environments/dev/nodes") //
+                  .addHeader("X-Chef-Version", ChefApi.VERSION) //
+                  .addHeader("Accept", MediaType.APPLICATION_JSON).build()), //
+            HttpResponse.builder().statusCode(404)
+                  .build());
+
+      assertTrue(api.listEnvironmentNodes("dev").isEmpty());
+   }
+
    @Override
    protected Module createModule() {
       return new TestChefRestClientModule();

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/eecfbf01/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
----------------------------------------------------------------------
diff --git a/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java b/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
index 7256323..0130821 100644
--- a/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
+++ b/core/src/test/java/org/jclouds/chef/internal/BaseChefApiLiveTest.java
@@ -72,6 +72,7 @@ import com.google.common.primitives.Bytes;
 public abstract class BaseChefApiLiveTest<A extends ChefApi> extends BaseChefLiveTest<A> {
    public static final String PREFIX = "jcloudstest-" + System.getProperty("user.name");
    public static final String ADMIN_PREFIX = "jcloudstest-adm-" + System.getProperty("user.name");
+   public static final String ENV_NODE = PREFIX + "-env-node";
 
    // It may take a bit until the search index is populated
    protected int maxWaitForIndexInMs = 60000;
@@ -470,12 +471,23 @@ public abstract class BaseChefApiLiveTest<A extends ChefApi> extends BaseChefLiv
       assertTrue(!recipeList.isEmpty());
    }
 
+   @Test(dependsOnMethods = "testCreateEnvironment")
+   public void testListEnvironmentNodes() {
+      api.deleteNode(ENV_NODE);
+      api.createNode(Node.builder().name(ENV_NODE).runListElement("role[" + PREFIX + "]").environment(PREFIX).build());
+      node = api.getNode(ENV_NODE);
+      assertNotNull(node, "Created node should not be null");
+      Set<String> nodeList = api.listEnvironmentNodes(PREFIX);
+      assertTrue(!nodeList.isEmpty());
+   }
+
    @AfterClass(groups = { "live", "integration" })
    @Override
    public void tearDown() {
       api.deleteClient(PREFIX);
       api.deleteClient(ADMIN_PREFIX);
       api.deleteNode(PREFIX);
+      api.deleteNode(ENV_NODE);
       api.deleteRole(PREFIX);
       api.deleteDatabag(PREFIX);
       api.deleteEnvironment(PREFIX);

http://git-wip-us.apache.org/repos/asf/incubator-jclouds-chef/blob/eecfbf01/core/src/test/resources/environment_nodes.json
----------------------------------------------------------------------
diff --git a/core/src/test/resources/environment_nodes.json b/core/src/test/resources/environment_nodes.json
new file mode 100644
index 0000000..92ef95a
--- /dev/null
+++ b/core/src/test/resources/environment_nodes.json
@@ -0,0 +1,5 @@
+{
+  "blah": "https://api.opscode.com/org/directory/nodes/blah",
+  "boxer": "https://api.opscode.com/org/directory/nodes/boxer",
+  "blarrrrgh": "https://api.opscode.com/org/directory/nodes/blarrrrgh"
+}