github.com/hashgraph/hedera-sdk-go/v2@v2.48.0/topic_message_query_e2e_test.go (about) 1 //go:build all || e2e || testnets 2 // +build all e2e testnets 3 4 package hedera 5 6 /*- 7 * 8 * Hedera Go SDK 9 * 10 * Copyright (C) 2020 - 2024 Hedera Hashgraph, LLC 11 * 12 * Licensed under the Apache License, Version 2.0 (the "License"); 13 * you may not use this file except in compliance with the License. 14 * You may obtain a copy of the License at 15 * 16 * http://www.apache.org/licenses/LICENSE-2.0 17 * 18 * Unless required by applicable law or agreed to in writing, software 19 * distributed under the License is distributed on an "AS IS" BASIS, 20 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 21 * See the License for the specific language governing permissions and 22 * limitations under the License. 23 * 24 */ 25 26 import ( 27 "errors" 28 "sync/atomic" 29 "testing" 30 "time" 31 32 "github.com/stretchr/testify/assert" 33 34 "github.com/stretchr/testify/require" 35 ) 36 37 // nolint 38 const bigContents = ` 39 Lorem ipsum dolor sit amet, consectetur adipiscing elit. Curabitur aliquam augue sem, ut mattis dui laoreet a. Curabitur consequat est euismod, scelerisque metus et, tristique dui. Nulla commodo mauris ut faucibus ultricies. Quisque venenatis nisl nec augue tempus, at efficitur elit eleifend. Duis pharetra felis metus, sed dapibus urna vehicula id. Duis non venenatis turpis, sit amet ornare orci. Donec non interdum quam. Sed finibus nunc et risus finibus, non sagittis lorem cursus. Proin pellentesque tempor aliquam. Sed congue nisl in enim bibendum, condimentum vehicula nisi feugiat. 40 41 Suspendisse non sodales arcu. Suspendisse sodales, lorem ac mollis blandit, ipsum neque porttitor nulla, et sodales arcu ante fermentum tellus. Integer sagittis dolor sed augue fringilla accumsan. Cras vitae finibus arcu, sit amet varius dolor. Etiam id finibus dolor, vitae luctus velit. Proin efficitur augue nec pharetra accumsan. Aliquam lobortis nisl diam, vel fermentum purus finibus id. Etiam at finibus orci, et tincidunt turpis. Aliquam imperdiet congue lacus vel facilisis. Phasellus id magna vitae enim dapibus vestibulum vitae quis augue. Morbi eu consequat enim. Maecenas neque nulla, pulvinar sit amet consequat sed, tempor sed magna. Mauris lacinia sem feugiat faucibus aliquet. Etiam congue non turpis at commodo. Nulla facilisi. 42 43 Nunc velit turpis, cursus ornare fringilla eu, lacinia posuere leo. Mauris rutrum ultricies dui et suscipit. Curabitur in euismod ligula. Curabitur vitae faucibus orci. Phasellus volutpat vestibulum diam sit amet vestibulum. In vel purus leo. Nulla condimentum lectus vestibulum lectus faucibus, id lobortis eros consequat. Proin mollis libero elit, vel aliquet nisi imperdiet et. Morbi ornare est velit, in vehicula nunc malesuada quis. Donec vehicula convallis interdum. 44 45 Integer pellentesque in nibh vitae aliquet. Ut at justo id libero dignissim hendrerit. Interdum et malesuada fames ac ante ipsum primis in faucibus. Praesent quis ornare lectus. Nam malesuada non diam quis cursus. Phasellus a libero ligula. Suspendisse ligula elit, congue et nisi sit amet, cursus euismod dolor. Morbi aliquam, nulla a posuere pellentesque, diam massa ornare risus, nec eleifend neque eros et elit. 46 47 Pellentesque a sodales dui. Sed in efficitur ante. Duis eget volutpat elit, et ornare est. Nam felis dolor, placerat mattis diam id, maximus lobortis quam. Sed pellentesque lobortis sem sed placerat. Pellentesque augue odio, molestie sed lectus sit amet, congue volutpat massa. Quisque congue consequat nunc id fringilla. Duis semper nulla eget enim venenatis dapibus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Pellentesque varius turpis nibh, sit amet malesuada mauris malesuada quis. Vivamus dictum egestas placerat. Vivamus id augue elit. 48 49 Cras fermentum volutpat eros, vitae euismod lorem viverra nec. Donec lectus augue, porta eleifend odio sit amet, condimentum rhoncus urna. Nunc sed odio velit. Morbi non cursus odio, eget imperdiet erat. Nunc rhoncus massa non neque volutpat, sit amet faucibus ante congue. Phasellus nec lorem vel leo accumsan lobortis. Maecenas id ligula bibendum purus suscipit posuere ac eget diam. Nam in quam pretium, semper erat auctor, iaculis odio. Maecenas placerat, nisi ac elementum tempor, felis nulla porttitor orci, ac rhoncus diam justo in elit. Etiam lobortis fermentum ligula in tincidunt. Donec quis vestibulum nunc. Sed eros diam, interdum in porta lobortis, gravida eu magna. Donec diam purus, finibus et sollicitudin quis, fringilla nec nisi. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Curabitur ultricies sagittis dapibus. Etiam ullamcorper aliquet libero, eu venenatis mauris suscipit id. 50 51 Ut interdum eleifend sem, vel bibendum ipsum volutpat eget. Nunc ac dignissim augue. Aliquam ornare aliquet magna id dignissim. Vestibulum velit sem, lacinia eu rutrum in, rhoncus vitae mauris. Pellentesque scelerisque pulvinar mauris non cursus. Integer id dolor porta, bibendum sem vel, pretium tortor. Fusce a nisi convallis, interdum quam condimentum, suscipit dolor. Sed magna diam, efficitur non nunc in, tincidunt varius mi. Aliquam ullamcorper nulla eu fermentum bibendum. Vivamus a felis pretium, hendrerit enim vitae, hendrerit leo. Suspendisse lacinia lectus a diam consectetur suscipit. Aenean hendrerit nisl sed diam venenatis pellentesque. Nullam egestas lectus a consequat pharetra. Vivamus ornare tellus auctor, facilisis lacus id, feugiat dui. Nam id est ut est rhoncus varius. 52 53 Aenean vel vehicula erat. Aenean gravida risus vitae purus sodales, quis dictum enim porta. Ut elit elit, fermentum sed posuere non, accumsan eu justo. Integer porta malesuada quam, et elementum massa suscipit nec. Donec in elit diam. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Duis suscipit vel ante volutpat vestibulum. 54 55 Pellentesque ex arcu, euismod et sapien ut, vulputate suscipit enim. Donec mattis sagittis augue, et mattis lacus. Cras placerat consequat lorem sed luctus. Nam suscipit aliquam sem ac imperdiet. Mauris a semper augue, pulvinar fringilla magna. Integer pretium massa non risus commodo hendrerit. Sed dictum libero id erat sodales mattis. Etiam auctor dolor lectus, ut sagittis enim lobortis vitae. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Curabitur nec orci lobortis, cursus risus eget, sollicitudin massa. Integer vel tincidunt mi, id eleifend quam. Nullam facilisis nisl eu mauris congue, vitae euismod nisi malesuada. Vivamus sit amet urna et libero sagittis dictum. 56 57 In hac habitasse platea dictumst. Aliquam erat volutpat. Ut dictum, mi a viverra venenatis, mi urna pulvinar nisi, nec gravida lectus diam eget urna. Ut dictum sit amet nisl ut dignissim. Sed sed mauris scelerisque, efficitur augue in, vulputate turpis. Proin dolor justo, bibendum et sollicitudin feugiat, imperdiet sed mi. Sed elementum vitae massa vel lobortis. Cras vitae massa sit amet libero dictum tempus. 58 59 Vivamus ut mauris lectus. Curabitur placerat ornare scelerisque. Cras malesuada nunc quis tortor pretium bibendum vel sed dui. Cras lobortis nibh eu erat blandit, sit amet consequat neque fermentum. Phasellus imperdiet molestie tristique. Cras auctor purus erat, id mollis ligula porttitor eget. Mauris porta pharetra odio et finibus. Suspendisse eu est a ligula bibendum cursus. Mauris ac laoreet libero. Nullam volutpat sem quis rhoncus gravida. 60 61 Donec malesuada lacus ac iaculis cursus. Sed sem orci, feugiat ac est ut, ultricies posuere nisi. Suspendisse potenti. Phasellus ut ultricies purus. Etiam sem tortor, fermentum quis aliquam eget, consequat ut nulla. Aliquam dictum metus in mi fringilla, vel gravida nulla accumsan. Cras aliquam eget leo vel posuere. Vivamus vitae malesuada nunc. Morbi placerat magna mi, id suscipit lacus auctor quis. Nam at lorem vel odio finibus fringilla ut ac velit. Donec laoreet at nibh quis vehicula. 62 63 Fusce ac tristique nisi. Donec leo nisi, consectetur at tellus sit amet, consectetur ultrices dui. Quisque gravida mollis tempor. Maecenas semper, sapien ut dignissim feugiat, massa enim viverra dolor, non varius eros nulla nec felis. Nunc massa lacus, ornare et feugiat id, bibendum quis purus. Praesent viverra elit sit amet purus consectetur venenatis. Maecenas nibh risus, elementum sit amet enim sagittis, ultrices malesuada lectus. Vivamus non felis ante. Ut vulputate ex arcu. Aliquam porta gravida porta. Aliquam eros leo, malesuada quis eros non, maximus tristique neque. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Etiam ligula orci, mollis vel luctus nec, venenatis vitae est. Fusce rutrum convallis nisi. 64 65 Nunc laoreet eget nibh in feugiat. Pellentesque nec arcu cursus, gravida dolor a, pellentesque nisi. Praesent vel justo blandit, placerat risus eget, consectetur orci. Sed maximus metus mi, ut euismod augue ultricies in. Nunc id risus hendrerit, aliquet lorem nec, congue justo. Vestibulum vel nunc ac est euismod mattis ac vitae nulla. Donec blandit luctus mauris, sit amet bibendum dui egestas et. Aenean nec lorem nec elit ornare rutrum nec eget ligula. Fusce a ipsum vitae neque elementum pharetra. Pellentesque ullamcorper ullamcorper libero, vitae porta sem sagittis vel. Interdum et malesuada fames ac ante ipsum primis in faucibus. 66 67 Duis at massa sit amet risus pellentesque varius sit amet vitae eros. Cras tempor aliquet sapien, vehicula varius neque volutpat et. Donec purus nibh, pellentesque ut lobortis nec, ultricies ultricies nisl. Sed accumsan ut dui sit amet vulputate. Suspendisse eu facilisis massa, a hendrerit mauris. Nulla elementum molestie tincidunt. Donec mi justo, ornare vel tempor id, gravida et orci. Nam molestie erat nec nisi bibendum accumsan. Duis vitae tempor ante. Morbi congue mauris vel sagittis facilisis. Vivamus vehicula odio orci, a tempor nibh euismod in. Proin mattis, nibh at feugiat porta, purus velit posuere felis, quis volutpat sapien dui vel odio. Nam fermentum sem nec euismod aliquet. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Aliquam erat volutpat. 68 69 Mauris congue lacus tortor. Pellentesque arcu eros, accumsan imperdiet porttitor vitae, mattis nec justo. Nullam ac aliquam mauris. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Suspendisse potenti. Fusce accumsan tempus felis a sagittis. Maecenas et velit odio. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Aliquam eros lacus, volutpat non urna sed, tincidunt ullamcorper elit. Sed sit amet gravida libero. In varius mi vel diam sollicitudin mollis. 70 71 Aenean varius, diam vitae hendrerit feugiat, libero augue ultrices odio, eget consequat sem tellus eu nisi. Nam dapibus enim et auctor sollicitudin. Nunc iaculis eros orci, ac accumsan eros malesuada ut. Ut semper augue felis, nec sodales lorem consectetur non. Cras gravida eleifend est, et sagittis eros imperdiet congue. Fusce id tellus dapibus nunc scelerisque tempus. Donec tempor placerat libero, in commodo nisi bibendum eu. Donec id eros non est sollicitudin luctus. Duis bibendum bibendum tellus nec viverra. Aliquam non faucibus ex, nec luctus dui. Curabitur efficitur varius urna non dignissim. Suspendisse elit elit, ultrices in elementum eu, tempor at magna. 72 73 Nunc in purus sit amet mi laoreet pulvinar placerat eget sapien. Donec vel felis at dui ultricies euismod quis vel neque. Donec tincidunt urna non eros pretium blandit. Nullam congue tincidunt condimentum. Curabitur et libero nibh. Proin ultricies risus id imperdiet scelerisque. Suspendisse purus mi, viverra vitae risus ut, tempus tincidunt enim. Ut luctus lobortis nisl, eget venenatis tortor cursus non. Mauris finibus nisl quis gravida ultricies. Fusce elementum lacus sit amet nunc congue, in porta nulla tincidunt. 74 75 Mauris ante risus, imperdiet blandit posuere in, blandit eu ipsum. Integer et auctor arcu. Integer quis elementum purus. Nunc in ultricies nisl, sed rutrum risus. Suspendisse venenatis eros nec lorem rhoncus, in scelerisque velit condimentum. Etiam condimentum quam felis, in elementum odio mattis et. In ut nibh porttitor, hendrerit tellus vel, luctus magna. Vestibulum et ligula et dolor pellentesque porta. Aenean efficitur porta massa et bibendum. Nulla vehicula sem in risus volutpat, a eleifend elit maximus. 76 77 Proin orci lorem, auctor a felis eu, pretium lobortis nulla. Phasellus aliquam efficitur interdum. Sed sit amet velit rutrum est dictum facilisis. Duis cursus enim at nisl tincidunt, eu molestie elit vehicula. Cras pellentesque nisl id enim feugiat fringilla. In quis tincidunt neque. Nam eu consectetur dolor. Ut id interdum mauris. Mauris nunc tortor, placerat in tempor ut, vestibulum eu nisl. Integer vel dapibus ipsum. Nunc id erat pulvinar, tincidunt magna id, condimentum massa. Pellentesque consequat est eget odio placerat vehicula. Etiam augue neque, sagittis non leo eu, tristique scelerisque dui. Ut dui urna, blandit quis urna ac, tincidunt tristique turpis. 78 79 Suspendisse venenatis rhoncus ligula ultrices condimentum. In id laoreet eros. Suspendisse suscipit fringilla leo id euismod. Sed in quam libero. Ut at ligula tellus. Sed tristique gravida dui, at egestas odio aliquam iaculis. Praesent imperdiet velit quis nibh consequat, quis pretium sem sagittis. Donec tortor ex, congue sit amet pulvinar ac, rutrum non est. Praesent ipsum magna, venenatis sit amet vulputate id, eleifend ac ipsum. 80 81 In consequat, nisi iaculis laoreet elementum, massa mauris varius nisi, et porta nisi velit at urna. Maecenas sit amet aliquet eros, a rhoncus nisl. Maecenas convallis enim nunc. Morbi purus nisl, aliquam ac tincidunt sed, mattis in augue. Quisque et elementum quam, vitae maximus orci. Suspendisse hendrerit risus nec vehicula placerat. Nulla et lectus nunc. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. 82 83 Etiam ut sodales ex. Nulla luctus, magna eu scelerisque sagittis, nibh quam consectetur neque, non rutrum dolor metus nec ex. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Sed egestas augue elit, sollicitudin accumsan massa lobortis ac. Curabitur placerat, dolor a aliquam maximus, velit ipsum laoreet ligula, id ullamcorper lacus nibh eget nisl. Donec eget lacus venenatis enim consequat auctor vel in. 84 ` 85 86 func TestIntegrationTopicMessageQueryCanExecute(t *testing.T) { 87 t.Parallel() 88 env := NewIntegrationTestEnv(t) 89 var finished int32 // 0 for false, 1 for true 90 91 resp, err := NewTopicCreateTransaction(). 92 SetAdminKey(env.Client.GetOperatorPublicKey()). 93 SetNodeAccountIDs(env.NodeAccountIDs). 94 Execute(env.Client) 95 96 require.NoError(t, err) 97 98 receipt, err := resp.SetValidateStatus(true).GetReceipt(env.Client) 99 require.NoError(t, err) 100 101 time.Sleep(3 * time.Second) 102 103 topicID := *receipt.TopicID 104 assert.NotNil(t, topicID) 105 106 start := time.Now() 107 108 _, err = NewTopicMessageQuery(). 109 SetTopicID(topicID). 110 SetStartTime(time.Unix(0, 0)). 111 SetLimit(1). 112 SetCompletionHandler(func() { 113 atomic.StoreInt32(&finished, 1) 114 }). 115 Subscribe(env.Client, func(message TopicMessage) { 116 println(string(message.Contents)) 117 atomic.StoreInt32(&finished, 1) 118 }) 119 require.NoError(t, err) 120 121 resp, err = NewTopicMessageSubmitTransaction(). 122 SetNodeAccountIDs([]AccountID{resp.NodeID}). 123 SetMessage("message"). 124 SetTopicID(topicID). 125 Execute(env.Client) 126 require.NoError(t, err) 127 128 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 129 require.NoError(t, err) 130 131 for { 132 condition := atomic.LoadInt32(&finished) == 1 || uint64(time.Since(start).Seconds()) > 60 133 if condition { 134 break 135 } 136 137 time.Sleep(3 * time.Second) 138 } 139 140 resp, err = NewTopicDeleteTransaction(). 141 SetTopicID(topicID). 142 SetNodeAccountIDs([]AccountID{resp.NodeID}). 143 Execute(env.Client) 144 require.NoError(t, err) 145 146 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 147 require.NoError(t, err) 148 149 if atomic.LoadInt32(&finished) != 1 { 150 err = errors.New("Message was not received within 60 seconds") 151 } 152 require.NoError(t, err) 153 154 err = CloseIntegrationTestEnv(env, nil) 155 require.NoError(t, err) 156 } 157 158 func TestIntegrationTopicMessageQueryNoTopicID(t *testing.T) { 159 t.Parallel() 160 env := NewIntegrationTestEnv(t) 161 var wait int32 = 1 // 1 for true, 0 for false 162 resp, err := NewTopicCreateTransaction(). 163 SetAdminKey(env.Client.GetOperatorPublicKey()). 164 SetNodeAccountIDs(env.NodeAccountIDs). 165 Execute(env.Client) 166 167 require.NoError(t, err) 168 169 receipt, err := resp.SetValidateStatus(true).GetReceipt(env.Client) 170 require.NoError(t, err) 171 172 topicID := *receipt.TopicID 173 assert.NotNil(t, topicID) 174 175 start := time.Now() 176 177 _, err = NewTopicMessageQuery(). 178 SetTopicID(topicID). 179 SetStartTime(time.Unix(0, 0)). 180 Subscribe(env.Client, func(message TopicMessage) { 181 if string(message.Contents) == bigContents { 182 atomic.StoreInt32(&wait, 0) 183 } 184 }) 185 require.NoError(t, err) 186 187 _, err = NewTopicMessageSubmitTransaction(). 188 SetNodeAccountIDs([]AccountID{resp.NodeID}). 189 SetMessage([]byte(bigContents)). 190 Execute(env.Client) 191 assert.Error(t, err) 192 if err != nil { 193 require.ErrorContains(t, err, "exceptional precheck status INVALID_TOPIC_ID") 194 } 195 196 for { 197 condition := atomic.LoadInt32(&wait) == 0 || err != nil || uint64(time.Since(start).Seconds()) > 30 198 if condition { 199 break 200 } 201 202 time.Sleep(3 * time.Second) 203 } 204 205 resp, err = NewTopicDeleteTransaction(). 206 SetTopicID(topicID). 207 SetNodeAccountIDs([]AccountID{resp.NodeID}). 208 Execute(env.Client) 209 require.NoError(t, err) 210 211 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 212 require.NoError(t, err) 213 214 if atomic.LoadInt32(&wait) == 1 { 215 err = errors.New("Message was not received within 30 seconds") 216 } 217 assert.Error(t, err) 218 219 err = CloseIntegrationTestEnv(env, nil) 220 require.NoError(t, err) 221 } 222 223 func TestIntegrationTopicMessageQueryNoMessage(t *testing.T) { 224 t.Parallel() 225 env := NewIntegrationTestEnv(t) 226 var wait int32 = 1 // 1 for true, 0 for false 227 resp, err := NewTopicCreateTransaction(). 228 SetAdminKey(env.Client.GetOperatorPublicKey()). 229 SetNodeAccountIDs(env.NodeAccountIDs). 230 Execute(env.Client) 231 232 require.NoError(t, err) 233 234 receipt, err := resp.SetValidateStatus(true).GetReceipt(env.Client) 235 require.NoError(t, err) 236 237 topicID := *receipt.TopicID 238 assert.NotNil(t, topicID) 239 240 start := time.Now() 241 242 _, err = NewTopicMessageQuery(). 243 SetTopicID(topicID). 244 SetStartTime(time.Unix(0, 0)). 245 Subscribe(env.Client, func(message TopicMessage) { 246 if string(message.Contents) == bigContents { 247 atomic.StoreInt32(&wait, 0) 248 } 249 }) 250 require.NoError(t, err) 251 252 _, err = NewTopicMessageSubmitTransaction(). 253 SetNodeAccountIDs([]AccountID{resp.NodeID}). 254 SetTopicID(topicID). 255 Execute(env.Client) 256 assert.Error(t, err) 257 if err != nil { 258 assert.Equal(t, "no transactions to execute", err.Error()) 259 } 260 261 for { 262 condition := atomic.LoadInt32(&wait) == 0 || err != nil || uint64(time.Since(start).Seconds()) > 30 263 if condition { 264 break 265 } 266 267 time.Sleep(3 * time.Second) 268 } 269 270 resp, err = NewTopicDeleteTransaction(). 271 SetTopicID(topicID). 272 SetNodeAccountIDs([]AccountID{resp.NodeID}). 273 Execute(env.Client) 274 require.NoError(t, err) 275 276 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 277 require.NoError(t, err) 278 279 if atomic.LoadInt32(&wait) == 1 { 280 err = errors.New("Message was not received within 30 seconds") 281 } 282 283 assert.Error(t, err) 284 285 err = CloseIntegrationTestEnv(env, nil) 286 require.NoError(t, err) 287 } 288 289 func TestIntegrationTopicMessageQueryNoStartTime(t *testing.T) { 290 t.Parallel() 291 env := NewIntegrationTestEnv(t) 292 var finished int32 = 0 // 0 for false, 1 for true 293 294 resp, err := NewTopicCreateTransaction(). 295 SetAdminKey(env.Client.GetOperatorPublicKey()). 296 SetNodeAccountIDs(env.NodeAccountIDs). 297 Execute(env.Client) 298 299 require.NoError(t, err) 300 301 receipt, err := resp.SetValidateStatus(true).GetReceipt(env.Client) 302 require.NoError(t, err) 303 304 topicID := *receipt.TopicID 305 assert.NotNil(t, topicID) 306 307 start := time.Now() 308 309 _, err = NewTopicMessageQuery(). 310 SetTopicID(topicID). 311 SetLimit(14). 312 SetEndTime(time.Now().Add(time.Second*20)). 313 Subscribe(env.Client, func(message TopicMessage) { 314 if string(message.Contents) == bigContents { 315 atomic.StoreInt32(&finished, 1) 316 } 317 }) 318 319 require.NoError(t, err) 320 321 resp, err = NewTopicMessageSubmitTransaction(). 322 SetNodeAccountIDs([]AccountID{resp.NodeID}). 323 SetMessage([]byte(bigContents)). 324 SetTopicID(topicID). 325 Execute(env.Client) 326 require.NoError(t, err) 327 328 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 329 require.NoError(t, err) 330 331 for { 332 condition := atomic.LoadInt32(&finished) == 1 || uint64(time.Since(start).Seconds()) > 60 333 if condition { 334 break 335 } 336 337 time.Sleep(3 * time.Second) 338 } 339 340 resp, err = NewTopicDeleteTransaction(). 341 SetTopicID(topicID). 342 SetNodeAccountIDs([]AccountID{resp.NodeID}). 343 Execute(env.Client) 344 require.NoError(t, err) 345 346 _, err = resp.SetValidateStatus(true).GetReceipt(env.Client) 347 require.NoError(t, err) 348 349 if atomic.LoadInt32(&finished) == 0 { 350 err = errors.New("Message was not received within 60 seconds") 351 } 352 353 assert.NoError(t, err) 354 355 err = CloseIntegrationTestEnv(env, nil) 356 require.NoError(t, err) 357 } 358 359 func TestIntegrationTopicMessageQueryWrongMessageType(t *testing.T) { 360 t.Parallel() 361 env := NewIntegrationTestEnv(t) 362 var finished int32 // 0 for false, 1 for true 363 364 resp, err := NewTopicCreateTransaction(). 365 SetAdminKey(env.Client.GetOperatorPublicKey()). 366 SetNodeAccountIDs(env.NodeAccountIDs). 367 Execute(env.Client) 368 369 require.NoError(t, err) 370 371 receipt, err := resp.SetValidateStatus(true).GetReceipt(env.Client) 372 require.NoError(t, err) 373 374 time.Sleep(3 * time.Second) 375 376 topicID := *receipt.TopicID 377 assert.NotNil(t, topicID) 378 379 _, err = NewTopicMessageQuery(). 380 SetTopicID(topicID). 381 SetStartTime(time.Unix(0, 0)). 382 SetLimit(1). 383 SetCompletionHandler(func() { 384 atomic.StoreInt32(&finished, 1) 385 }). 386 Subscribe(env.Client, func(message TopicMessage) { 387 println(string(message.Contents)) 388 atomic.StoreInt32(&finished, 1) 389 }) 390 require.NoError(t, err) 391 392 resp, err = NewTopicMessageSubmitTransaction(). 393 SetNodeAccountIDs([]AccountID{resp.NodeID}). 394 SetMessage(1234). // wrong message type 395 SetTopicID(topicID). 396 Execute(env.Client) 397 require.ErrorContains(t, err, "no transactions to execute") 398 }