/* * 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 } } } } }