Google App Engine 테스트에서 Datastore 항목 쿼리
Datastore의 쿼리 기능을 활용하는 코드를 테스트할 때 개발자는 내부 기능 구현에도 불구하고 오류가 발생할 수 있습니다. 응용 프로그램. 이러한 불일치는 대부분의 Datastore 쿼리의 최종 일관성 특성에서 발생합니다.
제공된 코드에서 항목은 Put() 메서드를 사용하여 Datastore에 삽입된 다음 GetAll()을 사용하여 이를 검색하는 쿼리가 이어집니다. 그러나 데이터 저장소에서 부과된 지연 시간 시뮬레이션으로 인해 쿼리는 결과를 반환하지 않습니다. 이 문제를 해결하려면 다음 두 가지 접근 방식을 취할 수 있습니다.
예(Strongly Consistent Datastore):
import ( "context" "cloud.google.com/go/datastore" "github.com/GoogleCloudPlatform/go-cloud-testing-gce" ) func TestEntityQueryStronglyConsistent(t *testing.T) { ctx := context.Background() c, err := aetest.NewContext(ctx, aetest.Options{ StronglyConsistentDatastore: true, }) if err != nil { t.Fatal(err) } defer c.Close() 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!