mirror of https://github.com/apache/jclouds.git
Add the listUsageRecords API operation
This commit is contained in:
parent
1fbc029bc8
commit
35e034a29a
|
@ -20,9 +20,11 @@ package org.jclouds.cloudstack.features;
|
||||||
|
|
||||||
import com.google.common.util.concurrent.ListenableFuture;
|
import com.google.common.util.concurrent.ListenableFuture;
|
||||||
import org.jclouds.cloudstack.domain.JobResult;
|
import org.jclouds.cloudstack.domain.JobResult;
|
||||||
|
import org.jclouds.cloudstack.domain.UsageRecord;
|
||||||
import org.jclouds.cloudstack.filters.QuerySigner;
|
import org.jclouds.cloudstack.filters.QuerySigner;
|
||||||
import org.jclouds.cloudstack.functions.DateToYyyyMmDd;
|
import org.jclouds.cloudstack.functions.DateToYyyyMmDd;
|
||||||
import org.jclouds.cloudstack.options.GenerateUsageRecordsOptions;
|
import org.jclouds.cloudstack.options.GenerateUsageRecordsOptions;
|
||||||
|
import org.jclouds.cloudstack.options.ListUsageRecordsOptions;
|
||||||
import org.jclouds.rest.annotations.ParamParser;
|
import org.jclouds.rest.annotations.ParamParser;
|
||||||
import org.jclouds.rest.annotations.QueryParams;
|
import org.jclouds.rest.annotations.QueryParams;
|
||||||
import org.jclouds.rest.annotations.RequestFilters;
|
import org.jclouds.rest.annotations.RequestFilters;
|
||||||
|
@ -33,6 +35,7 @@ import javax.ws.rs.GET;
|
||||||
import javax.ws.rs.QueryParam;
|
import javax.ws.rs.QueryParam;
|
||||||
import javax.ws.rs.core.MediaType;
|
import javax.ws.rs.core.MediaType;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides asynchronous access to CloudStack usage features.
|
* Provides asynchronous access to CloudStack usage features.
|
||||||
|
@ -52,4 +55,10 @@ public interface GlobalUsageAsyncClient {
|
||||||
@Consumes(MediaType.APPLICATION_JSON)
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
ListenableFuture<JobResult> generateUsageRecords(@QueryParam("startdate") @ParamParser(DateToYyyyMmDd.class) Date start, @QueryParam("enddate") @ParamParser(DateToYyyyMmDd.class) Date end, GenerateUsageRecordsOptions... options);
|
ListenableFuture<JobResult> generateUsageRecords(@QueryParam("startdate") @ParamParser(DateToYyyyMmDd.class) Date start, @QueryParam("enddate") @ParamParser(DateToYyyyMmDd.class) Date end, GenerateUsageRecordsOptions... options);
|
||||||
|
|
||||||
|
@GET
|
||||||
|
@QueryParams(keys = "command", values = "listUsageRecords")
|
||||||
|
@SelectJson("usagerecord")
|
||||||
|
@Consumes(MediaType.APPLICATION_JSON)
|
||||||
|
ListenableFuture<Set<UsageRecord>> listUsageRecords(@QueryParam("startdate") @ParamParser(DateToYyyyMmDd.class) Date start, @QueryParam("enddate") @ParamParser(DateToYyyyMmDd.class) Date end, ListUsageRecordsOptions... options);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,4 +41,6 @@ public interface GlobalUsageClient {
|
||||||
|
|
||||||
JobResult generateUsageRecords(Date start, Date end, GenerateUsageRecordsOptions... options);
|
JobResult generateUsageRecords(Date start, Date end, GenerateUsageRecordsOptions... options);
|
||||||
|
|
||||||
|
Set<UsageRecord> listUsageRecords(Date start, Date end, ListUsageRecordsOptions... options);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,73 @@
|
||||||
|
/**
|
||||||
|
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. jclouds 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.cloudstack.options;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableSet;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Options to the GlobalUsageClient.listUsageOptions() API call
|
||||||
|
*
|
||||||
|
* @author Richard Downer
|
||||||
|
*/
|
||||||
|
public class ListUsageRecordsOptions extends AccountInDomainOptions {
|
||||||
|
|
||||||
|
public static final ListUsageRecordsOptions NONE = new ListUsageRecordsOptions();
|
||||||
|
|
||||||
|
public static class Builder {
|
||||||
|
public static ListUsageRecordsOptions accountInDomain(String account, long domainId) {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions();
|
||||||
|
return options.accountInDomain(account, domainId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ListUsageRecordsOptions domainId(long domainId) {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions();
|
||||||
|
return options.domainId(domainId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ListUsageRecordsOptions accountId(long accountId) {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions();
|
||||||
|
return options.accountId(accountId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ListUsageRecordsOptions keyword(String keyword) {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions();
|
||||||
|
return options.keyword(keyword);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ListUsageRecordsOptions accountInDomain(String account, long domain) {
|
||||||
|
return (ListUsageRecordsOptions) super.accountInDomain(account, domain);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ListUsageRecordsOptions domainId(long domainId) {
|
||||||
|
return (ListUsageRecordsOptions) super.domainId(domainId);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ListUsageRecordsOptions accountId(long accountId) {
|
||||||
|
this.queryParameters.replaceValues("accountid", ImmutableSet.of(accountId + ""));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ListUsageRecordsOptions keyword(String keyword) {
|
||||||
|
this.queryParameters.replaceValues("keyword", ImmutableSet.of(keyword));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
|
@ -20,6 +20,7 @@ package org.jclouds.cloudstack.features;
|
||||||
|
|
||||||
import com.google.inject.TypeLiteral;
|
import com.google.inject.TypeLiteral;
|
||||||
import org.jclouds.cloudstack.options.GenerateUsageRecordsOptions;
|
import org.jclouds.cloudstack.options.GenerateUsageRecordsOptions;
|
||||||
|
import org.jclouds.cloudstack.options.ListUsageRecordsOptions;
|
||||||
import org.jclouds.http.HttpRequest;
|
import org.jclouds.http.HttpRequest;
|
||||||
import org.jclouds.http.functions.ParseFirstJsonValueNamed;
|
import org.jclouds.http.functions.ParseFirstJsonValueNamed;
|
||||||
import org.jclouds.rest.functions.MapHttp4xxCodesToExceptions;
|
import org.jclouds.rest.functions.MapHttp4xxCodesToExceptions;
|
||||||
|
@ -89,6 +90,56 @@ public class GlobalUsageAsyncClientTest extends BaseCloudStackAsyncClientTest<Gl
|
||||||
checkFilters(httpRequest);
|
checkFilters(httpRequest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testListUsageRecords() throws Exception {
|
||||||
|
Calendar c = Calendar.getInstance(TimeZone.getTimeZone("GMT"));
|
||||||
|
c.set(Calendar.YEAR, 2012);
|
||||||
|
c.set(Calendar.MONTH, Calendar.JANUARY);
|
||||||
|
c.set(Calendar.DAY_OF_MONTH, 1);
|
||||||
|
Date start = c.getTime();
|
||||||
|
c.set(Calendar.DAY_OF_MONTH, 31);
|
||||||
|
Date end = c.getTime();
|
||||||
|
|
||||||
|
Method method = GlobalUsageAsyncClient.class.getMethod("listUsageRecords",
|
||||||
|
Date.class, Date.class, ListUsageRecordsOptions[].class);
|
||||||
|
HttpRequest httpRequest = processor.createRequest(method, start, end);
|
||||||
|
|
||||||
|
assertRequestLineEquals(httpRequest,
|
||||||
|
"GET http://localhost:8080/client/api?response=json&command=listUsageRecords&startdate=2012-01-01&enddate=2012-01-31 HTTP/1.1");
|
||||||
|
assertNonPayloadHeadersEqual(httpRequest, "Accept: application/json\n");
|
||||||
|
assertPayloadEquals(httpRequest, null, null, false);
|
||||||
|
|
||||||
|
assertResponseParserClassEquals(method, httpRequest, ParseFirstJsonValueNamed.class);
|
||||||
|
assertSaxResponseParserClassEquals(method, null);
|
||||||
|
assertExceptionParserClassEquals(method, MapHttp4xxCodesToExceptions.class);
|
||||||
|
|
||||||
|
checkFilters(httpRequest);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testListUsageRecordsOptions() throws Exception {
|
||||||
|
Calendar c = Calendar.getInstance(TimeZone.getTimeZone("GMT"));
|
||||||
|
c.set(Calendar.YEAR, 2012);
|
||||||
|
c.set(Calendar.MONTH, Calendar.JANUARY);
|
||||||
|
c.set(Calendar.DAY_OF_MONTH, 1);
|
||||||
|
Date start = c.getTime();
|
||||||
|
c.set(Calendar.DAY_OF_MONTH, 31);
|
||||||
|
Date end = c.getTime();
|
||||||
|
|
||||||
|
Method method = GlobalUsageAsyncClient.class.getMethod("listUsageRecords",
|
||||||
|
Date.class, Date.class, ListUsageRecordsOptions[].class);
|
||||||
|
HttpRequest httpRequest = processor.createRequest(method, start, end, ListUsageRecordsOptions.Builder.accountInDomain("fred", 42).accountId(41).keyword("bob"));
|
||||||
|
|
||||||
|
assertRequestLineEquals(httpRequest,
|
||||||
|
"GET http://localhost:8080/client/api?response=json&command=listUsageRecords&startdate=2012-01-01&enddate=2012-01-31&account=fred&domainid=42&accountid=41&keyword=bob HTTP/1.1");
|
||||||
|
assertNonPayloadHeadersEqual(httpRequest, "Accept: application/json\n");
|
||||||
|
assertPayloadEquals(httpRequest, null, null, false);
|
||||||
|
|
||||||
|
assertResponseParserClassEquals(method, httpRequest, ParseFirstJsonValueNamed.class);
|
||||||
|
assertSaxResponseParserClassEquals(method, null);
|
||||||
|
assertExceptionParserClassEquals(method, MapHttp4xxCodesToExceptions.class);
|
||||||
|
|
||||||
|
checkFilters(httpRequest);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected TypeLiteral<RestAnnotationProcessor<GlobalUsageAsyncClient>> createTypeLiteral() {
|
protected TypeLiteral<RestAnnotationProcessor<GlobalUsageAsyncClient>> createTypeLiteral() {
|
||||||
return new TypeLiteral<RestAnnotationProcessor<GlobalUsageAsyncClient>>() {
|
return new TypeLiteral<RestAnnotationProcessor<GlobalUsageAsyncClient>>() {
|
||||||
|
|
|
@ -0,0 +1,76 @@
|
||||||
|
/**
|
||||||
|
* Licensed to jclouds, Inc. (jclouds) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. jclouds 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.cloudstack.options;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableSet;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
|
||||||
|
import static org.jclouds.cloudstack.options.ListUsageRecordsOptions.Builder.*;
|
||||||
|
import static org.testng.Assert.assertEquals;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Options to the GlobalUsageClient.listUsageOptions() API call
|
||||||
|
*
|
||||||
|
* @author Richard Downer
|
||||||
|
*/
|
||||||
|
@Test(groups = "unit")
|
||||||
|
public class ListUsageRecordsOptionsTest {
|
||||||
|
|
||||||
|
public void testAccountInDomain() {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions().accountInDomain("fred", 42);
|
||||||
|
assertEquals(ImmutableSet.of("fred"), options.buildQueryParameters().get("account"));
|
||||||
|
assertEquals(ImmutableSet.of("42"), options.buildQueryParameters().get("domainid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testAccountInDomainStatic() {
|
||||||
|
ListUsageRecordsOptions options = accountInDomain("fred", 42);
|
||||||
|
assertEquals(ImmutableSet.of("fred"), options.buildQueryParameters().get("account"));
|
||||||
|
assertEquals(ImmutableSet.of("42"), options.buildQueryParameters().get("domainid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testDomainId() {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions().domainId(42);
|
||||||
|
assertEquals(ImmutableSet.of("42"), options.buildQueryParameters().get("domainid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testDomainIdStatic() {
|
||||||
|
ListUsageRecordsOptions options = domainId(42);
|
||||||
|
assertEquals(ImmutableSet.of("42"), options.buildQueryParameters().get("domainid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testAccountId() {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions().accountId(41);
|
||||||
|
assertEquals(ImmutableSet.of("41"), options.buildQueryParameters().get("accountid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testAccountIdStatic() {
|
||||||
|
ListUsageRecordsOptions options = accountId(41);
|
||||||
|
assertEquals(ImmutableSet.of("41"), options.buildQueryParameters().get("accountid"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testKeyword() {
|
||||||
|
ListUsageRecordsOptions options = new ListUsageRecordsOptions().keyword("bob");
|
||||||
|
assertEquals(ImmutableSet.of("bob"), options.buildQueryParameters().get("keyword"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testKeywordStatic() {
|
||||||
|
ListUsageRecordsOptions options = keyword("bob");
|
||||||
|
assertEquals(ImmutableSet.of("bob"), options.buildQueryParameters().get("keyword"));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue