Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
S
Server-FastAPI
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Mundra, Anil
Server-FastAPI
Commits
d91dc14a
Commit
d91dc14a
authored
Feb 12, 2022
by
Mundra, Anil
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
final commit
parent
d0f7081b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
138 additions
and
1 deletion
+138
-1
main.cpython-310.pyc
app/__pycache__/main.cpython-310.pyc
+0
-0
main.py
app/main.py
+138
-1
No files found.
app/__pycache__/main.cpython-310.pyc
View file @
d91dc14a
No preview for this file type
app/main.py
View file @
d91dc14a
...
@@ -9,6 +9,17 @@ import time
...
@@ -9,6 +9,17 @@ import time
from
pydantic
import
BaseModel
from
pydantic
import
BaseModel
from
fastapi.middleware.cors
import
CORSMiddleware
from
fastapi.middleware.cors
import
CORSMiddleware
import
snowflake.connector
import
snowflake.connector
import
datetime
from
collections
import
namedtuple
def
create_record
(
obj
,
fields
):
''' given obj from db returns named tuple with fields mapped to values '''
Record
=
namedtuple
(
"Record"
,
fields
)
mappings
=
dict
(
zip
(
fields
,
obj
))
return
Record
(
**
mappings
)
class
User
(
BaseModel
):
class
User
(
BaseModel
):
email
:
str
email
:
str
password
:
str
password
:
str
...
@@ -191,4 +202,130 @@ async def execute_testcases():
...
@@ -191,4 +202,130 @@ async def execute_testcases():
curs1
.
execute
(
"select current date;"
)
curs1
.
execute
(
"select current date;"
)
#fetch result
#fetch result
print
(
curs1
.
fetchone
()[
0
])
print
(
curs1
.
fetchone
()[
0
])
return
{
'data'
:
curs1
.
fetchone
()[
0
]}
return
{
'data'
:
curs1
.
fetchone
()[
0
]}
\ No newline at end of file
@
app
.
get
(
"/executetests/{id}"
)
async
def
execute_tests
(
id
:
int
):
cursor
.
execute
(
"SELECT * FROM steps WHERE suiteid =
%
s"
,
(
str
(
id
),))
tests
=
cursor
.
fetchall
()
conn
.
commit
()
cursor
.
execute
(
"DELETE FROM results WHERE testsuite_id =
%
s RETURNING *"
,
(
str
(
id
),))
conn
.
commit
()
# print(tests)
all_tests
=
[]
for
row
in
tests
:
all_tests
.
append
(
dict
(
row
))
test_case_details
=
[]
for
test
in
all_tests
:
test_case
=
test
[
'name'
]
.
lower
()
if
"record count"
in
test_case
:
log_msg
=
[]
message
=
f
'>>> Database connection established {datetime.datetime.now()}'
log_msg
.
append
(
message
)
message
=
f
'>>> User successfully authenticated {datetime.datetime.now()}'
log_msg
.
append
(
message
)
message
=
f
'>>> record count check execution started at {datetime.datetime.now()}'
log_msg
.
append
(
message
)
message
=
f
'>>> query execution starts for source records -- time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
cursor
.
execute
(
"SELECT * FROM employee_demo"
)
source_records
=
cursor
.
fetchall
()
source_length
=
len
(
source_records
)
message
=
f
'>>> length of the suorce records are {len(source_records)} -- time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
curs1
.
execute
(
"SELECT * FROM EMPLOYEE_DEMO"
)
message
=
f
'>>> query execution starts for target records -- time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
target_records
=
curs1
.
fetchall
()
target_length
=
len
(
target_records
)
message
=
f
'>>> length of the target records are {len(target_records)}: -- time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
message
=
f
'>>> validating the record count source vs target: -- time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
if
source_length
==
target_length
:
message
=
f
'>>> source and target rowcount is matching: time: {datetime.datetime.now()}'
log_msg
.
append
(
message
)
message
=
f
'>>> capturing and saving the results to the system'
log_msg
.
append
(
message
)
temp_str
=
''
i
=
0
for
log
in
log_msg
:
if
not
(
i
==
0
):
temp_str
=
temp_str
+
','
+
log
i
=
i
+
1
# cursor.execute("DELETE FROM results WHERE testsuite_id = %s RETURNING *", (str(id),))
# conn.commit()
cursor
.
execute
(
"INSERT INTO results(testcase_name, testsuite_id, testcase_description, project_id, execution_status, log) VALUES(
%
s,
%
s,
%
s,
%
s,
%
s,
%
s) RETURNING *"
,
(
test
[
'name'
],
id
,
test
[
'description'
],
'PROJECT_SETUP'
,
'PASS'
,
temp_str
))
test
=
cursor
.
fetchone
()
conn
.
commit
()
# print(test)
elif
"column checks"
in
test_case
:
# cursor.execute("DELETE FROM results WHERE testsuite_id = %s RETURNING *", (str(id),))
# conn.commit()
cursor
.
execute
(
"SELECT * FROM employee_demo"
)
col_names_source
=
[
desc
[
0
]
for
desc
in
cursor
.
description
]
# rows_source = cursor.fetchall()
# conn.commit()
# result = []
# for row in rows_source:
# result.append(create_record(row, col_names_source))
curs1
.
execute
(
"SELECT * FROM EMPLOYEE_DEMO"
)
target_names_source
=
[
desc
[
0
]
for
desc
in
curs1
.
description
]
conn1
.
commit
()
# print(col_names_source)
# print(target_names_source)
column_check
=
True
for
source_column
,
target_column
in
zip
(
col_names_source
,
target_names_source
):
if
not
source_column
.
lower
()
==
target_column
.
lower
():
column_check
=
False
if
column_check
:
cursor
.
execute
(
"INSERT INTO results(testcase_name, testsuite_id, testcase_description, project_id, execution_status, log) VALUES(
%
s,
%
s,
%
s,
%
s,
%
s,
%
s) RETURNING *"
,
(
test
[
'name'
],
id
,
test
[
'description'
],
'PROJECT_SETUP'
,
'PASS'
,
'Long String'
))
test
=
cursor
.
fetchone
()
conn
.
commit
()
elif
"duplicates check"
in
test_case
:
cursor
.
execute
(
"SELECT name, designation, COUNT(*) FROM employee_demo GROUP BY name, designation HAVING COUNT(*) > 1"
)
source_dupliactes_count
=
cursor
.
fetchall
()
conn
.
commit
()
# print(source_dupliactes_count)
curs1
.
execute
(
"SELECT name, designation, COUNT(*) FROM employee_demo GROUP BY name, designation HAVING COUNT(*) > 1"
)
target_dupliactes_count
=
cursor
.
fetchall
()
conn1
.
commit
()
if
len
(
source_dupliactes_count
)
==
0
and
len
(
target_dupliactes_count
)
==
0
:
cursor
.
execute
(
"INSERT INTO results(testcase_name, testsuite_id, testcase_description, project_id, execution_status, log) VALUES(
%
s,
%
s,
%
s,
%
s,
%
s,
%
s) RETURNING *"
,
(
test
[
'name'
],
id
,
test
[
'description'
],
'PROJECT_SETUP'
,
'PASS'
,
'Long String'
))
test
=
cursor
.
fetchone
()
conn
.
commit
()
return
{
'data'
:
'results saved successful'
}
@
app
.
get
(
"/results"
)
async
def
get_tests
():
# cur = conn.cursor(cursor_factory=psycopg2.extras.DictCursor)
cursor
.
execute
(
"SELECT * FROM results"
)
projects
=
cursor
.
fetchall
()
conn
.
commit
()
all_results
=
[]
for
row
in
projects
:
all_results
.
append
(
dict
(
row
))
return
{
"data"
:
all_results
}
@
app
.
get
(
"/logs/{testsuite_id}/{id}"
)
async
def
get_tests
(
testsuite_id
:
int
,
id
:
int
):
# cur = conn.cursor(cursor_factory=psycopg2.extras.DictCursor)
cursor
.
execute
(
f
"SELECT log FROM results WHERE testsuite_id = '{str(testsuite_id)}' AND id = '{str(id)}'"
)
logs
=
cursor
.
fetchall
()
conn
.
commit
()
message
=
logs
[
0
][
0
]
# all_tests = []
# for row in logs:
# all_tests.append(dict(row))
return
{
message
}
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment