Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
package org.gcube.accounting.datamodel.usagerecords;
|
|
|
|
|
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Set;
|
|
|
|
|
|
|
|
import org.gcube.accounting.datamodel.UsageRecord;
|
|
|
|
import org.gcube.accounting.datamodel.basetypes.AbstractStorageStatusRecord;
|
2017-09-06 11:47:13 +02:00
|
|
|
import org.gcube.common.authorization.library.provider.SecurityTokenProvider;
|
|
|
|
import org.gcube.common.scope.api.ScopeProvider;
|
Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
import org.gcube.documentstore.exception.InvalidValueException;
|
|
|
|
import org.gcube.documentstore.records.Record;
|
2019-11-15 13:38:37 +01:00
|
|
|
import org.gcube.testutility.ContextTest;
|
Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
import org.gcube.testutility.TestUsageRecord;
|
|
|
|
import org.junit.Assert;
|
|
|
|
import org.junit.Test;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @author Alessandro Pieve (ISTI - CNR) alessandro.pieve@isti.cnr.it
|
|
|
|
*
|
|
|
|
*/
|
2019-11-15 13:38:37 +01:00
|
|
|
public class StorageStatusRecordTest extends ContextTest {
|
Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(StorageStatusRecordTest.class);
|
|
|
|
|
|
|
|
public static Set<String> getExpectedRequiredFields(){
|
|
|
|
Set<String> expectedRequiredFields = new HashSet<String>();
|
|
|
|
expectedRequiredFields.add(Record.ID);
|
|
|
|
expectedRequiredFields.add(UsageRecord.CONSUMER_ID);
|
|
|
|
expectedRequiredFields.add(UsageRecord.CREATION_TIME);
|
|
|
|
expectedRequiredFields.add(UsageRecord.SCOPE);
|
|
|
|
expectedRequiredFields.add(UsageRecord.OPERATION_RESULT);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_VOLUME);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_COUNT);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_TYPE);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_SERVICECLASS);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_SERVICENAME);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.DATA_SERVICEID);
|
|
|
|
expectedRequiredFields.add(AbstractStorageStatusRecord.PROVIDER_ID);
|
|
|
|
|
|
|
|
return expectedRequiredFields;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test(expected=InvalidValueException.class)
|
|
|
|
public void scopeNotSetValidationError() throws InvalidValueException {
|
2017-09-06 11:47:13 +02:00
|
|
|
SecurityTokenProvider.instance.reset();
|
|
|
|
ScopeProvider.instance.reset();
|
Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
StorageStatusRecord usageRecord = TestUsageRecord.createTestStorageVolumeUsageRecord();
|
|
|
|
usageRecord.validate();
|
|
|
|
logger.debug("{}", usageRecord);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void testRequiredFields() throws InvalidValueException{
|
2017-09-06 11:47:13 +02:00
|
|
|
SecurityTokenProvider.instance.reset();
|
|
|
|
ScopeProvider.instance.reset();
|
Add a new UsageRecord for Storage Volume
e.g.
{
"scope": "/gcube",
"operationCount": 2,
"dataCount": 2802,
"dataServiceName": "dataServiceName",
"endTime": 1480606453491,
"consumerId": "alessandro.pieve",
"startTime": 1480606453487,
"id": "6e6808bf-3567-4ebf-93d3-0d55c97202a1",
"dataVolume": 5104,
"dataType": "STORAGE",
"operationResult": "SUCCESS",
"dataServiceId": "dataServiceId",
"aggregated": true,
"providerId": "testprotocol://providerURI",
"creationTime": 1480606453494,
"recordType": "StorageStatusRecord",
"dataServiceClass": "dataServiceClass"
}
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/accounting/accounting-lib@141599 82a268e6-3cf1-43bd-a215-b396298e98cf
2017-01-17 11:59:14 +01:00
|
|
|
StorageStatusRecord usageRecord = TestUsageRecord.createTestStorageVolumeUsageRecord();
|
|
|
|
Assert.assertTrue(usageRecord.getScope()==null);
|
|
|
|
usageRecord.setScope(TestUsageRecord.TEST_SCOPE);
|
|
|
|
|
|
|
|
Set<String> expectedRequiredFields = getExpectedRequiredFields();
|
|
|
|
logger.debug("Expected Required Fields : {}", expectedRequiredFields);
|
|
|
|
|
|
|
|
Set<String> gotRequiredFields = usageRecord.getRequiredFields();
|
|
|
|
logger.debug("Got Required Fields : {}", gotRequiredFields);
|
|
|
|
|
|
|
|
Assert.assertTrue(expectedRequiredFields.containsAll(gotRequiredFields));
|
|
|
|
Assert.assertTrue(gotRequiredFields.containsAll(expectedRequiredFields));
|
|
|
|
|
|
|
|
usageRecord.validate();
|
|
|
|
logger.debug("{}", usageRecord);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|