blob: 0196e0e2ea89530b7c2271fefb56908d43556b12 [file] [log] [blame]
/*
* 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.apache.chemistry.opencmis.tck.tests.query;
import static org.apache.chemistry.opencmis.tck.CmisTestResultStatus.FAILURE;
import static org.apache.chemistry.opencmis.tck.CmisTestResultStatus.INFO;
import static org.apache.chemistry.opencmis.tck.CmisTestResultStatus.SKIPPED;
import java.util.Map;
import org.apache.chemistry.opencmis.client.api.ChangeEvent;
import org.apache.chemistry.opencmis.client.api.ChangeEvents;
import org.apache.chemistry.opencmis.client.api.CmisObject;
import org.apache.chemistry.opencmis.client.api.Session;
import org.apache.chemistry.opencmis.commons.data.RepositoryInfo;
import org.apache.chemistry.opencmis.commons.enums.BindingType;
import org.apache.chemistry.opencmis.commons.enums.CapabilityChanges;
import org.apache.chemistry.opencmis.commons.enums.ChangeType;
import org.apache.chemistry.opencmis.commons.exceptions.CmisObjectNotFoundException;
import org.apache.chemistry.opencmis.tck.CmisTestResult;
import org.apache.chemistry.opencmis.tck.impl.AbstractSessionTest;
/**
* Content Changes smoke test.
*/
public class ContentChangesSmokeTest extends AbstractSessionTest {
@Override
public void init(Map<String, String> parameters) {
super.init(parameters);
setName("Content Changes Smoke Test");
setDescription("Calls getContentChanges(). It does not check if the results are correct!");
}
@Override
public void run(Session session) {
CmisTestResult f;
if (supportsContentChanges(session)) {
// get a page of 100 entries
ChangeEvents events = session.getContentChanges(null, true, 1000, SELECT_ALL_NO_CACHE_OC);
f = createResult(FAILURE, "Change events are null!");
addResult(assertNotNull(events, null, f));
if (events != null && events.getChangeEvents() != null) {
if (getBinding() != BindingType.ATOMPUB) {
// the AtompPub binding does not return a change log token
f = createResult(FAILURE, "Change log token is null!");
addResult(assertNotNull(events.getLatestChangeLogToken(), null, f));
} else {
// an OpenCMIS based server transports the change log token
// in proprietary way.
CmisTestResult ocs = createResult(INFO,
"Change log token is null. The AtomPub binding does not return it.");
CmisTestResult nocs = createResult(INFO,
"Change log token is not null. Probably an OpenCMIS based server.");
addResult(assertNull(events.getLatestChangeLogToken(), ocs, nocs));
}
for (ChangeEvent event : events.getChangeEvents()) {
checkChangeEvent(session, event);
}
}
// get all entries
for (ChangeEvent event : session.getContentChanges(null, true, SELECT_ALL_NO_CACHE_OC)) {
checkChangeEvent(session, event);
}
} else {
addResult(createResult(SKIPPED, "Content Changes not supported. Test Skipped!"));
}
}
protected boolean supportsContentChanges(Session session) {
RepositoryInfo repository = session.getRepositoryInfo();
if (repository.getCapabilities().getChangesCapability() == null) {
return false;
}
return repository.getCapabilities().getChangesCapability() != CapabilityChanges.NONE;
}
protected void checkChangeEvent(Session session, ChangeEvent event) {
CmisTestResult f;
f = createResult(FAILURE, "Object Id is not set!");
addResult(assertStringNotEmpty(event.getObjectId(), null, f));
f = createResult(FAILURE, "Change Type is not set! Id: " + event.getObjectId());
addResult(assertNotNull(event.getChangeType(), null, f));
f = createResult(FAILURE, "Change Time is not set! Id: " + event.getObjectId());
addResult(assertNotNull(event.getChangeTime(), null, f));
if (event.getObjectId() != null) {
if (event.getChangeType() == ChangeType.DELETED) {
try {
session.getObject(event.getObjectId(), SELECT_ALL_NO_CACHE_OC);
addResult(createResult(
FAILURE,
"Change event indicates that an object has been deleted but it still exists. Id: "
+ event.getObjectId()));
} catch (CmisObjectNotFoundException e) {
// expected
}
} else {
try {
CmisObject object = session.getObject(event.getObjectId(), SELECT_ALL_NO_CACHE_OC);
addResult(checkObject(session, object, getAllProperties(object),
"Object check. Id: " + event.getObjectId()));
} catch (CmisObjectNotFoundException e) {
// object might have been deleted later
}
}
}
}
}