Получение ошибки с помощью тестового метода save() при тестировании репозитория CRUDJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Получение ошибки с помощью тестового метода save() при тестировании репозитория CRUD

Сообщение Anonymous »

Я пытаюсь написать несколько тестов для своего репозитория. Для тестового метода «сохранить» я получаю эту ошибку:
org.springframework.orm.ObjectOptimisticLockingFailureException: строка была обновлена ​​или
удалена другой транзакцией (или сопоставление несохраненных значений было неправильным ):
[ru.clevertec.newsonline.entity.News#7289c37a-8bfa-4092-872b-f1e4a8c319c6]
Другие методы проходят тесты. Почему я получил эту ошибку?

Код: Выделить всё

org.springframework.orm.ObjectOptimisticLockingFailureException: Row was updated or deleted by
another transaction (or unsaved-value mapping was incorrect):
[ru.clevertec.newsonline.entity.News#7289c37a-8bfa-4092-872b-f1e4a8c319c6]

Код: Выделить всё

@Repository
public interface NewsRepository extends JpaRepository, IRepository, IFilterEntityRepository {

}

Код: Выделить всё

public interface IRepository {

List findAll();

Page findAll(Pageable pageable);

Optional findById(UUID id);

E save(E e);

void delete(E e);

}

Код: Выделить всё

@DataJpaTest
@ActiveProfiles("test")
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
class NewsRepositoryIT {
@Test
public void shouldSaveNews() {
//given
News newNews = NewsTestBuilder.builder().build().buildNewsForSave();
//when
newsRepository.save(newNews);
//then
assertEquals(21, newsRepository.findAll().size());
assertTrue(((CrudRepository) newsRepository).findById(newNews.getNewsId()).isPresent());
}

Код: Выделить всё

    @ToString(exclude = {"pictures", "comments"})
@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
@Entity
@Table(name = "news", schema = "news_online")
public class News {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "news_id")
private UUID newsId;
@Column(name = "header_news")
private String headerNews;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "author_id")
private Author author;
@Column(name = "date_of_news", updatable = false)
@ColumnDefault(value = "CURRENT_TIMESTAMP")
private LocalDateTime dateOfNews;
@Column(name = "is_published")
private boolean isPublished;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "category_id")
private Category category;
@Column(name = "short_description", length = 500)
private String shortDescription;
@Column(name = "content_link")
private String contentLink;
@ManyToMany(mappedBy = "news", cascade = CascadeType.ALL)
@Fetch(value = FetchMode.SUBSELECT)
private List pictures;
@OneToMany(mappedBy = "news", cascade = CascadeType.ALL, orphanRemoval = true)
@Fetch(value = FetchMode.SUBSELECT)
private List comments;

public void addPicture(Picture picture) {
List news = picture.getNews();
news.add(this);
picture.setNews(news);
pictures.add(picture);
}

public void addComment(Comment comment) {
comment.setNews(this);
comments.add(comment);
}

}
добавьте код служебного класса NewsTestBuilder

Код: Выделить всё


@public News buildNewsForSave() {
return News.builder().newsId(UUID.fromString("7289c37a-8bfa-4092-872b-f1e4a8c319c6")).headerNews("Breaking news")
.isPublished(true).category(Category.builder().categoryId(UUID.fromString("3de78717-14f5-491e-a375-e122ec4dcbe2")).section(Section.CAR).build())
.shortDescription("Text").contentLink("static/text/news100.txt").build();
}

Я также пробовал использовать @Commit в методе тестирования. Я ожидал, что это пройдет, но мне это не помогло.

Подробнее здесь: https://stackoverflow.com/questions/793 ... repository
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»