尝试将项添加到存储库时atg.repository.RemovedItemException

时间:2014-02-19 12:53:50

标签: exception atg atg-dynamo atg-dust

我使用InternalProfileFormHandler添加了项InternalProfileRepository。它已成功将项目(用户:iuser310002)添加到预期的存储库。添加后,我访问了dyn / admin以打开存储库并删除了我刚刚使用<remove-item item-descriptor="user" id="iuser310002" />添加的项目。然后我再次使用调用的InternalProfileFormHandler来添加一个项目。不过这一次,我有atg.repository.RemovedItemExceptionAttempt to use an item which has been removed: user:iuser310002.

我不确定为什么要尝试创建一个与之前ID相同的新用户,即使我这样做了,为什么删除的项目会导致此问题。我正在为InternalProfileRepository使用默认的idGenerator /atg/dynamo/service/IdGenerator,所以我认为我不会生成相同的id。

以下是成功创建项目一次并且第二次失败的代码...

FormHandlerInvoker invoker = new FormHandlerInvoker("/atg/userprofiling/InternalProfileFormHandler", Nucleus.getSystemNucleus());

try {
    String paramName;
    int paramCounter = 1;
    while((paramName = (String) getCurrentTestParams().get("param" + paramCounter)) != null)
    {
        invoker.addInput(paramName, (String) getCurrentTestParams().get("value" + paramCounter));
        paramCounter++;
    }
} catch (ServletException e) {
    e.printStackTrace();
}
FormHandlerInvocationResult result;
ProfileFormHandler formHandler = null;
try {
    result = invoker.invoke();
    formHandler =
    (ProfileFormHandler)result.getDefaultFormHandler();
    formHandler.handleCreate(result.getRequest(), result.getResponse());
}

以下是异常日志...这是由formHandler.handleCreate方法调用引起的。

atg.repository.RemovedItemException: Attempt to use an item which has been removed: user:iuser310002
    at atg.adapter.gsa.ItemTransactionState.<init>(ItemTransactionState.java:385)
    at atg.adapter.gsa.GSAItem.getItemTransactionState(GSAItem.java:2421)
    at atg.adapter.gsa.GSAItem.getItemTransactionState(GSAItem.java:2364)
    at atg.adapter.gsa.GSAItem.getItemTransactionStateUnchecked(GSAItem.java:2600)
    at atg.adapter.gsa.GSAItem.getPropertyValue(GSAItem.java:1511)
    at atg.repository.RepositoryItemImpl.getPropertyValue(RepositoryItemImpl.java:151)
    at atg.adapter.composite.CompositeItem.createPropertyQuery(CompositeItem.java:739)
    at atg.adapter.composite.CompositeItem.getPropertyLinkedItem(CompositeItem.java:630)
    at atg.adapter.composite.CompositeItem.getContributingItem(CompositeItem.java:577)
    at atg.adapter.composite.CompositeItem.findContributingItem(CompositeItem.java:561)
    at atg.adapter.composite.MutableCompositeItem.findContributingItem(MutableCompositeItem.java:971)
    at atg.adapter.composite.MutableCompositeItem.getOrCreateContributingItem(MutableCompositeItem.java:985)
    at atg.adapter.composite.MutableCompositeItem.setPropertyValue(MutableCompositeItem.java:210)
    at atg.userprofiling.ProfileForm.updateProfileAttributes(ProfileForm.java:3761)
    at atg.userprofiling.ProfileForm.updateProfileAttributes(ProfileForm.java:3528)
    at atg.userprofiling.ProfileForm.createUser(ProfileForm.java:1507)
    at atg.userprofiling.ProfileForm.handleCreate(ProfileForm.java:1214)
    at atg.userprofiling.ProfileFormHandler.handleCreate(ProfileFormHandler.java:402)
    at atg.scenario.userprofiling.ScenarioProfileFormHandler.handleCreate(ScenarioProfileFormHandler.java:599)
    at atg.test.steps.CreateInternalUserStep.runTest(CreateInternalUserStep.java:45)

1 个答案:

答案 0 :(得分:0)

经过一番挖掘后,我想出了原因。除了创建用户外,还会自动为同一用户创建会话。通过在dyn / admin中转到此路径可以找到用户。 /atg/dynamo/servlet/sessiontracking/GenericSessionManager/notdefined/atg/userprofiling/Profile/

下次当我删除I​​nternalProfileRepository中的项目时,该项目正在被成功删除,但会话对象仍然存在。

当我再次调用formhandler.handleCreate时,它正在检查配置文件对象是否存在。当它找到用户时,它正在尝试更新同一个用户而不是创建一个新用户。因此我得到了RemovedItemException。

但是,我不太确定这是否符合预期。