| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | package query | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"database/sql" | 
					
						
							|  |  |  | 	"database/sql/driver" | 
					
						
							|  |  |  | 	"errors" | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"regexp" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"golang.org/x/text/language" | 
					
						
							| 
									
										
										
										
											2022-03-23 09:02:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-27 01:01:45 +02:00
										 |  |  | 	errs "github.com/zitadel/zitadel/internal/errors" | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | var ( | 
					
						
							|  |  |  | 	prepareCustomTextsStmt = `SELECT projections.custom_texts2.aggregate_id,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.sequence,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.creation_date,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.change_date,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.language,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.template,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.key,` + | 
					
						
							|  |  |  | 		` projections.custom_texts2.text,` + | 
					
						
							|  |  |  | 		` COUNT(*) OVER ()` + | 
					
						
							|  |  |  | 		` FROM projections.custom_texts2` + | 
					
						
							|  |  |  | 		` AS OF SYSTEM TIME '-1 ms'` | 
					
						
							|  |  |  | 	prepareCustomTextsCols = []string{ | 
					
						
							|  |  |  | 		"aggregate_id", | 
					
						
							|  |  |  | 		"sequence", | 
					
						
							|  |  |  | 		"creation_date", | 
					
						
							|  |  |  | 		"change_date", | 
					
						
							|  |  |  | 		"language", | 
					
						
							|  |  |  | 		"template", | 
					
						
							|  |  |  | 		"key", | 
					
						
							|  |  |  | 		"text", | 
					
						
							|  |  |  | 		"count", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | func Test_CustomTextPrepares(t *testing.T) { | 
					
						
							|  |  |  | 	type want struct { | 
					
						
							|  |  |  | 		sqlExpectations sqlExpectation | 
					
						
							|  |  |  | 		err             checkErr | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	tests := []struct { | 
					
						
							|  |  |  | 		name    string | 
					
						
							|  |  |  | 		prepare interface{} | 
					
						
							|  |  |  | 		want    want | 
					
						
							|  |  |  | 		object  interface{} | 
					
						
							|  |  |  | 	}{ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			name:    "prepareCustomTextQuery no result", | 
					
						
							|  |  |  | 			prepare: prepareCustomTextsQuery, | 
					
						
							|  |  |  | 			want: want{ | 
					
						
							|  |  |  | 				sqlExpectations: mockQueries( | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 					regexp.QuoteMeta(prepareCustomTextsStmt), | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 					nil, | 
					
						
							|  |  |  | 					nil, | 
					
						
							|  |  |  | 				), | 
					
						
							|  |  |  | 				err: func(err error) (error, bool) { | 
					
						
							|  |  |  | 					if !errs.IsNotFound(err) { | 
					
						
							|  |  |  | 						return fmt.Errorf("err should be zitadel.NotFoundError got: %w", err), false | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					return nil, true | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			object: &CustomTexts{CustomTexts: []*CustomText{}}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			name:    "prepareCustomTextQuery one result", | 
					
						
							|  |  |  | 			prepare: prepareCustomTextsQuery, | 
					
						
							|  |  |  | 			want: want{ | 
					
						
							|  |  |  | 				sqlExpectations: mockQueries( | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 					regexp.QuoteMeta(prepareCustomTextsStmt), | 
					
						
							|  |  |  | 					prepareCustomTextsCols, | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 					[][]driver.Value{ | 
					
						
							|  |  |  | 						{ | 
					
						
							|  |  |  | 							"agg-id", | 
					
						
							|  |  |  | 							uint64(20211109), | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							"en", | 
					
						
							|  |  |  | 							"template", | 
					
						
							|  |  |  | 							"key", | 
					
						
							|  |  |  | 							"text", | 
					
						
							|  |  |  | 						}, | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			object: &CustomTexts{ | 
					
						
							|  |  |  | 				SearchResponse: SearchResponse{ | 
					
						
							|  |  |  | 					Count: 1, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				CustomTexts: []*CustomText{ | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						AggregateID:  "agg-id", | 
					
						
							|  |  |  | 						CreationDate: testNow, | 
					
						
							|  |  |  | 						ChangeDate:   testNow, | 
					
						
							|  |  |  | 						Sequence:     20211109, | 
					
						
							|  |  |  | 						Language:     language.English, | 
					
						
							|  |  |  | 						Template:     "template", | 
					
						
							|  |  |  | 						Key:          "key", | 
					
						
							|  |  |  | 						Text:         "text", | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			name:    "prepareCustomTextQuery multiple result", | 
					
						
							|  |  |  | 			prepare: prepareCustomTextsQuery, | 
					
						
							|  |  |  | 			want: want{ | 
					
						
							|  |  |  | 				sqlExpectations: mockQueries( | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 					regexp.QuoteMeta(prepareCustomTextsStmt), | 
					
						
							|  |  |  | 					prepareCustomTextsCols, | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 					[][]driver.Value{ | 
					
						
							|  |  |  | 						{ | 
					
						
							|  |  |  | 							"agg-id", | 
					
						
							|  |  |  | 							uint64(20211109), | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							"en", | 
					
						
							|  |  |  | 							"template", | 
					
						
							|  |  |  | 							"key", | 
					
						
							|  |  |  | 							"text", | 
					
						
							|  |  |  | 						}, | 
					
						
							|  |  |  | 						{ | 
					
						
							|  |  |  | 							"agg-id", | 
					
						
							|  |  |  | 							uint64(20211109), | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							testNow, | 
					
						
							|  |  |  | 							"en", | 
					
						
							|  |  |  | 							"template", | 
					
						
							|  |  |  | 							"key2", | 
					
						
							|  |  |  | 							"text", | 
					
						
							|  |  |  | 						}, | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			object: &CustomTexts{ | 
					
						
							|  |  |  | 				SearchResponse: SearchResponse{ | 
					
						
							|  |  |  | 					Count: 2, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				CustomTexts: []*CustomText{ | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						AggregateID:  "agg-id", | 
					
						
							|  |  |  | 						CreationDate: testNow, | 
					
						
							|  |  |  | 						ChangeDate:   testNow, | 
					
						
							|  |  |  | 						Sequence:     20211109, | 
					
						
							|  |  |  | 						Language:     language.English, | 
					
						
							|  |  |  | 						Template:     "template", | 
					
						
							|  |  |  | 						Key:          "key", | 
					
						
							|  |  |  | 						Text:         "text", | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						AggregateID:  "agg-id", | 
					
						
							|  |  |  | 						CreationDate: testNow, | 
					
						
							|  |  |  | 						ChangeDate:   testNow, | 
					
						
							|  |  |  | 						Sequence:     20211109, | 
					
						
							|  |  |  | 						Language:     language.English, | 
					
						
							|  |  |  | 						Template:     "template", | 
					
						
							|  |  |  | 						Key:          "key2", | 
					
						
							|  |  |  | 						Text:         "text", | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			name:    "prepareCustomTextQuery sql err", | 
					
						
							|  |  |  | 			prepare: prepareCustomTextsQuery, | 
					
						
							|  |  |  | 			want: want{ | 
					
						
							|  |  |  | 				sqlExpectations: mockQueryErr( | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 					regexp.QuoteMeta(prepareCustomTextsStmt), | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 					sql.ErrConnDone, | 
					
						
							|  |  |  | 				), | 
					
						
							|  |  |  | 				err: func(err error) (error, bool) { | 
					
						
							|  |  |  | 					if !errors.Is(err, sql.ErrConnDone) { | 
					
						
							|  |  |  | 						return fmt.Errorf("err should be sql.ErrConnDone got: %w", err), false | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					return nil, true | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							| 
									
										
										
										
											2023-08-22 14:49:02 +02:00
										 |  |  | 			object: (*CustomText)(nil), | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	for _, tt := range tests { | 
					
						
							|  |  |  | 		t.Run(tt.name, func(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2023-02-27 22:36:43 +01:00
										 |  |  | 			assertPrepare(t, tt.prepare, tt.object, tt.want.sqlExpectations, tt.want.err, defaultPrepareArgs...) | 
					
						
							| 
									
										
										
										
											2021-12-16 15:21:37 +01:00
										 |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |