fixed conflicts

This commit is contained in:
shekhar-cis 2021-07-12 16:34:37 +05:30
commit de272b8b99
Signed by untrusted user: shekhar-cis
GPG Key ID: 8B2A6C8D5F7F1635
7 changed files with 49 additions and 140 deletions

View File

@ -51,3 +51,12 @@ class TeleniumTestProcess(TeleniumTestCase):
cleanup() cleanup()
cls.cli.app_quit() cls.cli.app_quit()
cls.process.kill() cls.process.kill()
def click_on(self, xpath, seconds=0.3):
"""this methos is used for on_click event with time"""
self.cli.click_on(xpath)
self.cli.sleep(seconds)
def drag(self, xpath1, xpath2):
self.cli.drag(xpath1, xpath2, 1)
self.cli.sleep(0.3)

View File

@ -7,12 +7,17 @@ class SettingScreen(TeleniumTestProcess):
def test_setting_screen(self): def test_setting_screen(self):
"""Show Setting Screen""" """Show Setting Screen"""
print("=====================Test -Show Setting Screen=====================") print("=====================Test -Show Setting Screen=====================")
self.cli.sleep(10)
# self.cli.wait_click("//MDToolbar/BoxLayout[0]/MDActionTopAppBarButton[0]", timeout=20)
self.cli.click_on('//MDToolbar/BoxLayout[0]/MDActionTopAppBarButton[0]')
self.cli.sleep(3) self.cli.sleep(3)
self.cli.drag("//NavigationItem[@text=\"Sent\"]", "//NavigationItem[@text=\"Inbox\"]", 1) # this is for opening Nav drawer
self.cli.sleep(3) self.click_on('//MDActionTopAppBarButton[@icon=\"menu\"]')
self.cli.click_on('//NavigationItem[7]') # checking state of Nav drawer
self.cli.sleep(2) self.assertEqual(self.cli.getattr('//MDNavigationDrawer', 'state'), 'open')
# this is for scrolling Nav drawer
self.drag("//NavigationItem[@text=\"Sent\"]", "//NavigationItem[@text=\"Inbox\"]")
# assert for checking scroll funcation
scroll_distance = self.cli.getattr('//ContentNavigationDrawer//ScrollView[0]', 'scroll_y')
self.assertLessEqual(scroll_distance, -0.0)
# this is for opening setting screen
self.click_on('//NavigationItem[@text=\"Settings\"]')
# Checking current screen
self.assertExists("//Setting[@name~=\"set\"]", timeout=2) self.assertExists("//Setting[@name~=\"set\"]", timeout=2)

View File

@ -59,7 +59,6 @@ requirements =
# requirements.source.kivy = ../../kivy # requirements.source.kivy = ../../kivy
# (list) Garden requirements # (list) Garden requirements
#requirements = kivy_garden.qrcode
#garden_requirements = qrcode #garden_requirements = qrcode
# (str) Presplash of the application # (str) Presplash of the application

View File

@ -8,13 +8,28 @@ from bmconfigparser import BMConfigParser
from network.threads import StoppableThread from network.threads import StoppableThread
fake_addresses = [ fake_addresses = {
'BM-2cXDconV3bk6nPwWgBwN7wXaqZoT1bEzGv', 'BM-2cUgQGcTLWAkC6dNsv2Bc8XB3Y1GEesVLV': {
'BM-2cTWjUVedYftZJbnZfs7MWts92v1R35Try', 'privsigningkey': '5KWXwYq1oJMzghUSJaJoWPn8VdeBbhDN8zFot1cBd6ezKKReqBd',
'BM-2cV1UN3er2YVQBcmJaaeYMXvpwBVokJNTo', 'privencryptionkey': '5JaeFJs8iPcQT3N8676r3gHKvJ5mTWXy1VLhGCEDqRs4vpvpxV8'
'BM-2cWVkWk3TyKUscdcn9E7s9hrwpv2ZsBBog', },
'BM-2cW2a5R1KidMGNByqPKn6nJDDnHtazoere' 'BM-2cUd2dm8MVMokruMTcGhhteTpyRZCAMhnA': {
] 'privsigningkey': '5JnJ79nkcwjo4Aj7iG8sFMkzYoQqWfpUjTcitTuFJZ1YKHZz98J',
'privencryptionkey': '5JXgNzTRouFLqSRFJvuHMDHCYPBvTeMPBiHt4Jeb6smNjhUNTYq'
},
'BM-2cWyvL54WytfALrJHZqbsDHca5QkrtByAW': {
'privsigningkey': '5KVE4gLmcfYVicLdgyD4GmnbBTFSnY7Yj2UCuytQqgBBsfwDhpi',
'privencryptionkey': '5JTw48CGm5CP8fyJUJQMq8HQANQMHDHp2ETUe1dgm6EFpT1egD7'
},
'BM-2cTE65PK9Y4AQEkCZbazV86pcQACocnRXd': {
'privsigningkey': '5KCuyReHx9MB4m5hhEyCWcLEXqc8rxhD1T2VWk8CicPFc8B6LaZ',
'privencryptionkey': '5KBRpwXdX3n2tP7f583SbFgfzgs6Jemx7qfYqhdH7B1Vhe2jqY6'
},
'BM-2cX5z1EgmJ87f2oKAwXdv4VQtEVwr2V3BG': {
'privsigningkey': '5K5UK7qED7F1uWCVsehudQrszLyMZxFVnP6vN2VDQAjtn5qnyRK',
'privencryptionkey': '5J5coocoJBX6hy5DFTWKtyEgPmADpSwfQTazMpU7QPeART6oMAu'
}
}
class FakeAddressGenerator(StoppableThread): class FakeAddressGenerator(StoppableThread):
@ -38,16 +53,19 @@ class FakeAddressGenerator(StoppableThread):
streamNumber = 1 streamNumber = 1
try: try:
if len(BMConfigParser().addresses()) > 0: if len(BMConfigParser().addresses()) > 0:
address = fake_addresses[len(BMConfigParser().addresses())] address = list(fake_addresses.keys())[len(BMConfigParser().addresses())]
else: else:
address = fake_addresses[0] address = list(fake_addresses.keys())[0]
label = queueValue[3] label = queueValue[3]
BMConfigParser().add_section(address) BMConfigParser().add_section(address)
BMConfigParser().set(address, 'label', label) BMConfigParser().set(address, 'label', label)
BMConfigParser().set(address, 'enabled', 'true') BMConfigParser().set(address, 'enabled', 'true')
BMConfigParser().set( BMConfigParser().set(
address, 'privencryptionkey', '5KUayt1aPSsNWsxMJnk27kv79wfRE3cWVPYLazyLQc752bXfQP3') address, 'privsigningkey', fake_addresses[address]['privsigningkey'])
BMConfigParser().set(
address, 'privencryptionkey', fake_addresses[address]['privencryptionkey'])
BMConfigParser().save() BMConfigParser().save()
queues.UISignalQueue.put(( queues.UISignalQueue.put((

View File

View File

@ -1,93 +0,0 @@
"""
A thread for creating addresses
"""
# import queues
try:
import queue as Queue
except ImportError:
import Queue
import logging
import random
from pybitmessage import state
import threading
from pybitmessage.bmconfigparser import BMConfigParser
# from network.threads import StoppableThread
fake_addresses = [
'BM-2cXDconV3bk6nPwWgBwN7wXaqZoT1bEzGv',
'BM-2cTWjUVedYftZJbnZfs7MWts92v1R35Try',
'BM-2cV1UN3er2YVQBcmJaaeYMXvpwBVokJNTo',
'BM-2cWVkWk3TyKUscdcn9E7s9hrwpv2ZsBBog',
'BM-2cW2a5R1KidMGNByqPKn6nJDDnHtazoere'
]
UISignalQueue = Queue.Queue()
addressGeneratorQueue = Queue.Queue()
class StoppableThread(threading.Thread):
"""Base class for application threads with stopThread method"""
name = None
logger = logging.getLogger('default')
def __init__(self, name=None):
if name:
self.name = name
super(StoppableThread, self).__init__(name=self.name)
self.stop = threading.Event()
self._stopped = False
random.seed()
self.logger.info('Init thread %s', self.name)
def stopThread(self):
"""Stop the thread"""
self._stopped = True
self.stop.set()
class FakeAddressGenerator(StoppableThread):
"""A thread for creating fake addresses"""
name = "addressGenerator"
def stopThread(self):
try:
addressGeneratorQueue.put(("stopThread", "data"))
except:
pass
super(FakeAddressGenerator, self).stopThread()
def run(self):
"""
Process the requests for addresses generation
from `.queues.addressGeneratorQueue`
"""
while state.shutdown == 0:
queueValue = 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()
UISignalQueue.put((
'updateStatusBar', ""
))
UISignalQueue.put(('writeNewAddressToTable', (
label, address, streamNumber)))
addressGeneratorQueue.task_done()
except IndexError:
self.logger.error(
'Program error: you can only create 5 fake addresses')

View File

@ -1,29 +0,0 @@
"""This module is for thread start."""
from pybitmessage import state
from pybitmessage.bitmessagekivy.mpybit import NavigateApp
from class_addressGenerator import FakeAddressGenerator
# from class_sqlThread import sqlThread
def main():
"""main method for starting threads"""
if state.enableObjProc:
# Start the address generation thread
addressGeneratorThread = FakeAddressGenerator()
# close the main program even if there are threads left
addressGeneratorThread.daemon = True
addressGeneratorThread.start()
# sqlLookup = sqlThread()
# DON'T close the main program even if there are threads left.
# The closeEvent should command this thread to exit gracefully.
# sqlLookup.daemon = False
# sqlLookup.start()
state.kivyapp = NavigateApp()
state.kivyapp.run()
if __name__ == '__main__':
main()