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  }