> 백엔드 개발 > Golang > Google App Engine에서 데이터 저장소 쿼리를 안정적으로 테스트하려면 어떻게 해야 합니까?

Google App Engine에서 데이터 저장소 쿼리를 안정적으로 테스트하려면 어떻게 해야 합니까?

Susan Sarandon
풀어 주다: 2024-12-07 15:46:15
원래의
671명이 탐색했습니다.

How Can I Reliably Test Datastore Queries in Google App Engine?

Google App Engine Datastore에서 쿼리 테스트

Datastore에서 중복 항목을 방지하려는 시도에서 쿼리를 테스트하는 데 어려움이 있습니다. 고유성을 보장해야 하는 기능입니다. 애플리케이션에서 기능이 올바르게 수행됨에도 불구하고 테스트가 반복적으로 실패합니다.

문제를 조사한 결과 테스트 컨텍스트 내에서 쿼리를 통해 데이터 저장소 데이터에 액세스하는 것이 불가능하다는 사실이 확인되었습니다. 이러한 불가능성은 Datastore 트랜잭션이 즉시 커밋되지 않아 쿼리 결과가 일관되지 않기 때문에 발생합니다.

datastore.Put() 및 q.GetAll() 작업 사이에 최소 100ms의 지연을 도입하면 테스트 케이스가 제공되면 테스트가 통과됩니다. 이는 지연으로 인해 트랜잭션이 커밋되어 데이터 일관성이 보장되기 때문입니다.

지연에 의존하지 않고 강력한 일관성을 보장하려면 테스트 컨텍스트를 생성할 때 StronglyCondependentDatastore: true 옵션을 사용할 수 있습니다. 이렇게 하면 모든 쿼리가 강력한 일관성을 유지하므로 쓰기 작업 후 즉시 데이터에 액세스할 수 있습니다.

다음은 StronglyCondependentDatastore 옵션을 사용하여 업데이트된 테스트 사례 버전입니다.

type Entity struct {
    Value string
}

func TestEntityQuery(t *testing.T) {
    c, err := aetest.NewContext(nil)
    if err != nil {
        t.Fatal(err)
    }
    defer c.Close()

    c.StronglyConsistentDatastore = true

    key := datastore.NewIncompleteKey(c, "Entity", nil)
    key, err = datastore.Put(c, key, &Entity{Value: "test"})
    if err != nil {
        t.Fatal(err)
    }

    q := datastore.NewQuery("Entity").Filter("Value =", "test")
    var entities []Entity
    keys, err := q.GetAll(c, &entities)
    if err != nil {
        t.Fatal(err)
    }
    if len(keys) == 0 {
        t.Error("No keys found in query")
    }
    if len(entities) == 0 {
        t.Error("No entities found in query")
    }
}
로그인 후 복사

위 내용은 Google App Engine에서 데이터 저장소 쿼리를 안정적으로 테스트하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿