atg.repository.RemovedItemException при попытке добавить элемент в репозиторий

Я использовал InternalProfileFormHandler добавить предмет InternalProfileRepository, Он успешно добавил элемент (пользователь:iuser310002) в предполагаемый репозиторий. После добавления я получил доступ к dyn/admin, чтобы открыть репозиторий и удалить элемент, который я только что добавил, используя <remove-item item-descriptor="user" id="iuser310002" />, Затем я снова использовал вызванный InternalProfileFormHandler, чтобы добавить еще один элемент. Однако на этот раз я получил atg.repository.RemovedItemException говоря это Attempt to use an item which has been removed: user:iuser310002.

Я не уверен, почему он пытается создать нового пользователя с тем же идентификатором, что и раньше, и даже если я это сделал, почему удаленный элемент должен вызывать эту проблему. Я использую по умолчанию idGenerator /atg/dynamo/service/IdGenerator для InternalProfileRepository, поэтому я не думаю, что будет генерировать тот же идентификатор.

Вот код, который успешно создал элемент один раз и завершился неудачей со второго раза...

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 ответ

После некоторых копаний я выяснил причину. Наряду с созданием пользователя, сеанс также создается для того же пользователя автоматически. Пользователь может быть найден, перейдя по этому пути в dyn/admin. /atg/dynamo/servlet/sessiontracking/GenericSessionManager/notdefined/atg/userprofiling/Profile/

В следующий раз, когда я удаляю элемент в InternalProfileRepository, элемент удаляется успешно, но объект сеанса все еще существует.

Когда я снова вызываю formhandler.handleCreate, он проверяет, существует ли объект профиля. Когда он нашел пользователя, он пытается обновить того же пользователя, а не создавать нового. Следовательно, я получаю исключение RemovedItemException.

Тем не менее, я не совсем уверен, если это то, что ожидается.

Другие вопросы по тегам