From 148d4a13332b409c6deec57ba8dcd83a68dd0e9d Mon Sep 17 00:00:00 2001 From: navjot Date: Thu, 8 Apr 2021 17:39:05 +0530 Subject: [PATCH] added fake addressGenerator thread --- src/bitmessagekivy/kv/popup.kv | 2 +- src/bitmessagekivy/mpybit.py | 1 + src/bitmessagekivy/tests/telenium_process.py | 3 +- src/bitmessagekivy/tests/test_addressbook.py | 8 ++- .../tests/test_myaddress_screen.py | 6 +- src/bitmessagekivy/tests/test_sent_message.py | 6 +- src/fake_addressGenerator.py | 60 +++++++++++++++++++ src/main_test.py | 5 +- 8 files changed, 80 insertions(+), 11 deletions(-) create mode 100644 src/fake_addressGenerator.py diff --git a/src/bitmessagekivy/kv/popup.kv b/src/bitmessagekivy/kv/popup.kv index 1a713de6..2e97b5fe 100644 --- a/src/bitmessagekivy/kv/popup.kv +++ b/src/bitmessagekivy/kv/popup.kv @@ -19,7 +19,7 @@ # spacing: "12dp" size_hint_y: None # height: "120dp" - height: 1.5*label.height+address.height + height: label.height+address.height BoxLayout: orientation: 'vertical' MDTextField: diff --git a/src/bitmessagekivy/mpybit.py b/src/bitmessagekivy/mpybit.py index 34fd1e49..1232c4d8 100644 --- a/src/bitmessagekivy/mpybit.py +++ b/src/bitmessagekivy/mpybit.py @@ -476,6 +476,7 @@ class NavigateApp(MDApp): state.in_composer = False self.root.ids.scr_mngr.current = 'inbox' elif self.root.ids.scr_mngr.current == "showqrcode": + self.set_common_header() self.root.ids.scr_mngr.current = 'myaddress' elif self.root.ids.scr_mngr.current == "random": self.root.ids.scr_mngr.current = 'login' diff --git a/src/bitmessagekivy/tests/telenium_process.py b/src/bitmessagekivy/tests/telenium_process.py index eafe0ff3..72513c3b 100644 --- a/src/bitmessagekivy/tests/telenium_process.py +++ b/src/bitmessagekivy/tests/telenium_process.py @@ -3,7 +3,8 @@ import shutil import tempfile from telenium.tests import TeleniumTestCase -from threads import addressGenerator, sqlThread +from threads import sqlThread + _files = ( diff --git a/src/bitmessagekivy/tests/test_addressbook.py b/src/bitmessagekivy/tests/test_addressbook.py index d2c6df41..4ae337cb 100644 --- a/src/bitmessagekivy/tests/test_addressbook.py +++ b/src/bitmessagekivy/tests/test_addressbook.py @@ -1,9 +1,11 @@ import time from bitmessagekivy.tests.telenium_process import TeleniumTestProcess -from bmconfigparser import BMConfigParser from .common import ordered -data = BMConfigParser().addresses() +data = [ + 'BM-2cWmjntZ47WKEUtocrdvs19y5CivpKoi1h', + 'BM-2cVpswZo8rWLXDVtZEUNcDQvnvHJ6TLRYr' +] class AddressBook(TeleniumTestProcess): @@ -60,7 +62,7 @@ class AddressBook(TeleniumTestProcess): self.cli.sleep(3) self.cli.execute('app.addingtoaddressbook()') self.cli.sleep(3) - self.cli.setattr('//GrashofPopup/BoxLayout[0]/MDTextField[0]','text','test2') + self.cli.setattr('//GrashofPopup/BoxLayout[0]/MDTextField[0]','text','test2 ') self.cli.sleep(3) self.cli.setattr('//GrashofPopup/BoxLayout[0]/MDTextField[1]','text',data[0]) self.cli.sleep(3) diff --git a/src/bitmessagekivy/tests/test_myaddress_screen.py b/src/bitmessagekivy/tests/test_myaddress_screen.py index 7fd7da3e..b28fe3e7 100644 --- a/src/bitmessagekivy/tests/test_myaddress_screen.py +++ b/src/bitmessagekivy/tests/test_myaddress_screen.py @@ -1,8 +1,10 @@ -from bmconfigparser import BMConfigParser from bitmessagekivy.tests.telenium_process import TeleniumTestProcess from .common import ordered -data = BMConfigParser().addresses() +data = [ + 'BM-2cWmjntZ47WKEUtocrdvs19y5CivpKoi1h', + 'BM-2cVpswZo8rWLXDVtZEUNcDQvnvHJ6TLRYr' +] class MyAddressScreen(TeleniumTestProcess): diff --git a/src/bitmessagekivy/tests/test_sent_message.py b/src/bitmessagekivy/tests/test_sent_message.py index dd04b881..9401b87e 100644 --- a/src/bitmessagekivy/tests/test_sent_message.py +++ b/src/bitmessagekivy/tests/test_sent_message.py @@ -1,8 +1,10 @@ from bitmessagekivy.tests.telenium_process import TeleniumTestProcess -from bmconfigparser import BMConfigParser from .common import ordered -data = BMConfigParser().addresses() +data = [ + 'BM-2cWmjntZ47WKEUtocrdvs19y5CivpKoi1h', + 'BM-2cVpswZo8rWLXDVtZEUNcDQvnvHJ6TLRYr' +] class SendMessage(TeleniumTestProcess): diff --git a/src/fake_addressGenerator.py b/src/fake_addressGenerator.py new file mode 100644 index 00000000..baca8d53 --- /dev/null +++ b/src/fake_addressGenerator.py @@ -0,0 +1,60 @@ +""" +A thread for creating addresses +""" + +import queues +import state +from bmconfigparser import BMConfigParser +from network.threads import StoppableThread + + +fake_addresses = [ + 'BM-2cXDconV3bk6nPwWgBwN7wXaqZoT1bEzGv', + 'BM-2cTWjUVedYftZJbnZfs7MWts92v1R35Try', + 'BM-2cV1UN3er2YVQBcmJaaeYMXvpwBVokJNTo', + 'BM-2cWVkWk3TyKUscdcn9E7s9hrwpv2ZsBBog', + 'BM-2cW2a5R1KidMGNByqPKn6nJDDnHtazoere' +] + +class FakeAddressGenerator(StoppableThread): + """A thread for creating fake addresses""" + name = "addressGenerator" + + def stopThread(self): + try: + queues.addressGeneratorQueue.put(("stopThread", "data")) + except: + pass + super(addressGenerator, self).stopThread() + + def run(self): + """ + Process the requests for addresses generation + from `.queues.addressGeneratorQueue` + """ + while state.shutdown == 0: + queueValue = queues.addressGeneratorQueue.get() + streamNumber = 1 + try: + if len(BMConfigParser().addresses()) > 0: + address = fake_addresses[len(BMConfigParser().addresses())] + else: + address = fake_addresses[0] + + label = queueValue[3] + BMConfigParser().add_section(address) + BMConfigParser().set(address, 'label', label) + BMConfigParser().set(address, 'enabled', 'true') + BMConfigParser().set( + address, 'privencryptionkey', '5KUayt1aPSsNWsxMJnk27kv79wfRE3cWVPYLazyLQc752bXfQP3') + BMConfigParser().save() + + queues.UISignalQueue.put(( + 'updateStatusBar', "" + )) + queues.UISignalQueue.put(('writeNewAddressToTable', ( + label, address, streamNumber))) + queues.addressGeneratorQueue.task_done() + except IndexError: + self.logger.error( + 'Program error: you can only create 5 fake addresses') diff --git a/src/main_test.py b/src/main_test.py index 161d4667..a057379b 100644 --- a/src/main_test.py +++ b/src/main_test.py @@ -1,12 +1,13 @@ """This module is for thread start.""" import state from bitmessagekivy.mpybit import NavigateApp -from threads import addressGenerator, sqlThread +from fake_addressGenerator import FakeAddressGenerator +from threads import sqlThread def main(): if state.enableObjProc: # Start the address generation thread - addressGeneratorThread = addressGenerator() + addressGeneratorThread = FakeAddressGenerator() # close the main program even if there are threads left addressGeneratorThread.daemon = True addressGeneratorThread.start()