github.com/weaviate/weaviate@v1.24.6/modules/qna-transformers/ask/graphql_argument_test.go (about)

     1  //                           _       _
     2  // __      _____  __ ___   ___  __ _| |_ ___
     3  // \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \
     4  //  \ V  V /  __/ (_| |\ V /| | (_| | ||  __/
     5  //   \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___|
     6  //
     7  //  Copyright © 2016 - 2024 Weaviate B.V. All rights reserved.
     8  //
     9  //  CONTACT: hello@weaviate.io
    10  //
    11  
    12  package ask
    13  
    14  import (
    15  	"testing"
    16  
    17  	"github.com/stretchr/testify/assert"
    18  	"github.com/tailor-inc/graphql"
    19  )
    20  
    21  func TestAskGraphQLArgument(t *testing.T) {
    22  	t.Run("should generate ask argument properly", func(t *testing.T) {
    23  		// given
    24  		prefix := "Prefix"
    25  		classname := "Class"
    26  		// when
    27  		ask := New(nil).askArgument(prefix, classname)
    28  
    29  		// then
    30  		// the built graphQL field needs to support this structure:
    31  		// ask {
    32  		//   question: "question?",
    33  		//   distance: 0.9
    34  		//   properties: ["prop1", "prop2"]
    35  		//   rerank: true
    36  		// }
    37  		assert.NotNil(t, ask)
    38  		assert.Equal(t, "QnATransformersPrefixClassAskInpObj", ask.Type.Name())
    39  		askFields, ok := ask.Type.(*graphql.InputObject)
    40  		assert.True(t, ok)
    41  		assert.NotNil(t, askFields)
    42  		assert.Equal(t, 5, len(askFields.Fields()))
    43  		fields := askFields.Fields()
    44  		question := fields["question"]
    45  		questionNonNull, questionNonNullOK := question.Type.(*graphql.NonNull)
    46  		assert.True(t, questionNonNullOK)
    47  		assert.Equal(t, "String", questionNonNull.OfType.Name())
    48  		assert.NotNil(t, question)
    49  		assert.NotNil(t, fields["certainty"])
    50  		assert.NotNil(t, fields["distance"])
    51  		properties := fields["properties"]
    52  		propertiesList, propertiesListOK := properties.Type.(*graphql.List)
    53  		assert.True(t, propertiesListOK)
    54  		assert.Equal(t, "String", propertiesList.OfType.Name())
    55  		assert.NotNil(t, fields["rerank"])
    56  	})
    57  }
    58  
    59  func TestAskGraphQLArgumentWithAutocorrect(t *testing.T) {
    60  	t.Run("should generate ask argument properly with autocorrect", func(t *testing.T) {
    61  		// given
    62  		prefix := "Prefix"
    63  		classname := "Class"
    64  		// when
    65  		ask := New(&fakeTransformer{}).askArgument(prefix, classname)
    66  
    67  		// then
    68  		// the built graphQL field needs to support this structure:
    69  		// ask {
    70  		//   question: "question?",
    71  		//   distance: 0.9
    72  		//   properties: ["prop1", "prop2"]
    73  		//   autocorrect: true
    74  		//   rerank: true
    75  		// }
    76  		assert.NotNil(t, ask)
    77  		assert.Equal(t, "QnATransformersPrefixClassAskInpObj", ask.Type.Name())
    78  		askFields, ok := ask.Type.(*graphql.InputObject)
    79  		assert.True(t, ok)
    80  		assert.NotNil(t, askFields)
    81  		assert.Equal(t, 6, len(askFields.Fields()))
    82  		fields := askFields.Fields()
    83  		question := fields["question"]
    84  		questionNonNull, questionNonNullOK := question.Type.(*graphql.NonNull)
    85  		assert.True(t, questionNonNullOK)
    86  		assert.Equal(t, "String", questionNonNull.OfType.Name())
    87  		assert.NotNil(t, question)
    88  		assert.NotNil(t, fields["certainty"])
    89  		assert.NotNil(t, fields["distance"])
    90  		properties := fields["properties"]
    91  		propertiesList, propertiesListOK := properties.Type.(*graphql.List)
    92  		assert.True(t, propertiesListOK)
    93  		assert.Equal(t, "String", propertiesList.OfType.Name())
    94  		assert.NotNil(t, fields["autocorrect"])
    95  		assert.NotNil(t, fields["rerank"])
    96  	})
    97  }