def _get_vista_data(self, cxn): query = RpcSelect() query.file = '459.01' query.iens = ',%d,' % (self.ien,) query.fields = '.01E;1;2;3;4;6;8;10;11;13;29;34;37;40;61;63;64;65;66;79;85;88;94;118;122;131;132;133;134;135;136;137;138' query.index = 'B' query.screen = 'I $P(^(0),U,10)="%s"' % (self.cp_nbr,) return query.find(cxn)
def _get_vista_data(self): query = RpcSelect() query.file = '410' query.fields = '.01;1;3;22;23;24;25;25.5;27;451' query.index = 'RB' query.frum = '{}-{}-{}-'.format( get_fiscal_start_date(self.fy, self.qtr), rpc_utils.primary_source_id(self.cxn.site_id), self.cp_nbr) query.part = query.frum query.identifier = ''.join( [ 'S X=$S($P(^(4),U,10)]"":"Y",1:"N") ', 'S Y=$S($P(^(7),U,6)]"":"Y",1:"N") ', 'S Z=$P(^(0),"-")_"-"_$P(^(4),U,5) ', 'S Z=$O(^PRC(442,"B",Z,0)) ', 'S Z1=$S(+Z=0:"X",$P($G(^PRC(442,Z,0)),U,2)=25:$P(^(7),U,2),1:"N") ', 'S Z2=$S(+Z\'=0:$P($$FP^PRCH0A(Z),U,2),1:"X")', 'D EN^DDIOL(X_U_Y_U_Z1_U_Z2)' ] ) return query.find(self.cxn)
def setUp(self): self.query = RpcSelect()
class TestRpcSelect(unittest.TestCase): def setUp(self): self.query = RpcSelect() def test_set_file(self): self.query.file = '200' self.assertEqual('200', self.query.file) def test_set_iens(self): try: self.query.iens = 'a' self.fail('Should not succeed') except RpcError as e: self.assertEqual('Invalid IENS', str(e)) try: self.query.iens = '67,,' self.fail('Should not succeed') except RpcError as e: self.assertEqual('Invalid IENS', str(e)) try: self.query.iens = ',,67,' self.fail('Should not succeed') except RpcError as e: self.assertEqual('Invalid IENS', str(e)) try: self.query.iens = '67,,4,' self.fail('Should not succeed') except RpcError as e: self.assertEqual('Invalid IENS', str(e)) self.query.iens = '67' self.assertEqual(',67,', self.query.iens) self.query.iens = ',67' self.assertEqual(',67,', self.query.iens) self.query.iens = ',67,' self.assertEqual(',67,', self.query.iens) self.query.iens = '67,44' self.assertEqual(',67,44,', self.query.iens) self.query.iens = ',67,44' self.assertEqual(',67,44,', self.query.iens) self.query.iens = '67,44,' self.assertEqual(',67,44,', self.query.iens) self.query.iens = ',67,44' self.assertEqual(',67,44,', self.query.iens) def test_set_fields(self): self.query.fields = '' self.assertEqual('@', self.query.fields) self.query.fields = '@' self.assertEqual('@', self.query.fields) self.query.fields = '.01;2;4;5;.141;8;9;11;29' self.assertEqual('@;.01;2;4;5;.141;8;9;11;29', self.query.fields) self.query.fields = '@;.01;2;4;5;.141;8;9;11;29' self.assertEqual('@;.01;2;4;5;.141;8;9;11;29', self.query.fields) def test_set_flags(self): self.query.flags = None self.assertEqual('IP', self.query.flags) self.query.flags = '' self.assertEqual('IP', self.query.flags) try: self.query.flags = 'I' except RpcError as e: self.assertEqual('Current version does packed queries only', str(e)) self.query.flags = 'BIP' self.assertEqual('BIP', self.query.flags) def test_prepare_param_list(self): self.query.file = '200' self.query.fields = '.01;2;4;5;.141;8;9;11;29' self.query.number = 1 self.query.frum = '546' expected = [ ('"FILE"', '200'), ('"FIELDS"', '@;.01;2;4;5;.141;8;9;11;29'), ('"FLAGS"', 'IP'), ('"MAX"', '1'), ('"FROM"', '545'), ('"XREF"', '#') ] self.query._prepare_param_list() self.assertEqual(expected, self.query.param_list) def test_prepare(self): self.query.file = '200' self.query.fields = '.01;2;4;5;.141;8;9;11;29' self.query.number = 1 self.query.frum = '546' expected = "[XWB]11302\x051.108\x0ADDR LISTER52006\"FILE\"003200t008\"FIELDS\"026@;.01;2;4;5;.141;8;9;11;29t007\"FLAGS\"002IPt005\"MAX\"0011t006\"FROM\"003545t006\"XREF\"001#f\x04" self.query._prepare() self.assertEqual(expected, self.query.rpc) def test_load(self): response = "[Misc]\r\nMORE^546^546^\r\n[MAP]\r\nIEN^.01I^2I^4I^5I^.141I^8I^9I^11I^29I\r\n[BEGIN_diDATA]\r\n546^ZZPROGRAMMER,NINE^@Jy$9BO\'9iCm#:x*p:\'E^F^^^2^666948848^tHffxTgZ)<4~.7`EUx}j^1043\r\n[END_diDATA]" expected = [ ['546','ZZPROGRAMMER,NINE',"@Jy$9BO'9iCm#:x*p:'E",'F','','','2','666948848',"tHffxTgZ)<4~.7`EUx}j",'1043'] ] actual = self.query._load(response) self.assertEqual(expected, actual) self.assertEqual(expected, self.query.records)