Building a Script: Steps and Best Practices for Implementation

undefined
B
U
I
L
D
I
N
G
 
A
 
S
C
R
I
P
T
Evan Heisman, PE
USACE IWR-HEC
21 August 2023
 
How do I go from an idea to implementation?
 
Steps to think through the scripting process
 
Outline some best practices
 
 
O
B
J
E
C
T
I
V
E
S
 
Before you start… Why write code?
 
Script lifecycle:
-
Designing a script
-
Writing a script
-
Testing a script
-
Maintaining a script
 
Some best practices
 
 
O
U
T
L
I
N
E
 
What’s the first question you should ask?
S
h
o
u
l
d
 
y
o
u
 
w
r
i
t
e
 
t
h
i
s
 
c
o
d
e
?
 
B
E
F
O
R
E
 
Y
O
U
 
S
T
A
R
T
Some factors to consider:
-
How often do we need to run this code?
-
Development time < expected time
-
Will the scripted solution do better?
-
How will you validate/test the code?
-
Who will maintain the code? 
-
Who / what will pay for it?
 
S
H
O
U
L
D
 
Y
O
U
 
W
R
I
T
E
 
T
H
I
S
 
C
O
D
E
?
 
From a 1970’s IBM training document…
 
-
Automation:
-
Repeatability of a task
-
Consistency between several tasks
-
Time-savings to users, labor savings to organization
 
-
Adding capabilities:
-
Some tasks are impossible to do “by hand” or with off-the-shelf solutions
-
Extending or customizing existing programs.
 
 
 
W
H
Y
 
W
R
I
T
E
 
C
O
D
E
?
 
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
 
F
O
U
R
 
S
T
E
P
S
 
D
o
c
u
m
e
n
t
 
r
e
q
u
i
r
e
m
e
n
t
s
 
/
 
s
p
e
c
i
f
i
c
a
t
i
o
n
s
!
 
- Inputs
 
- Calculations Performed
 
- Outputs
 
B
r
e
a
k
 
t
h
e
 
p
r
o
b
l
e
m
 
i
n
t
o
 
e
l
e
m
e
n
t
s
Define a “minimum viable product” (MVP)
Add more features after MVP is done
Iterate through the cycle for each part of the design
 
Specifications should inform testing
 
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
D
E
S
I
G
N
 
I
m
p
l
e
m
e
n
t
 
i
n
 
s
m
a
l
l
 
p
i
e
c
e
s
,
 
f
o
l
l
o
w
i
n
g
 
t
h
e
 
f
o
u
r
 
s
t
e
p
s
 
f
o
r
 
e
a
c
h
:
 
 
D
e
s
i
g
n
,
 
i
m
p
l
e
m
e
n
t
,
 
t
e
s
t
,
 
m
a
i
n
t
a
i
n
 
D
e
s
i
g
n
:
W
r
i
t
e
 
p
s
e
u
d
o
-
c
o
d
e
 
t
o
 
g
e
t
 
a
 
p
i
c
t
u
r
e
 
o
f
 
t
h
e
 
a
l
g
o
r
i
t
h
m
;
 Identify the inputs, computations, and outputs at each step
 
I
m
p
l
e
m
e
n
t
:
T
r
a
n
s
l
a
t
e
 
p
s
e
u
d
o
-
c
o
d
e
 
i
n
t
o
 
s
p
e
c
i
f
i
c
s
,
 
f
i
g
u
r
e
 
o
u
t
 
s
t
e
p
s
 
t
o
 
t
r
a
n
s
f
o
r
m
 
i
n
p
u
t
s
 
i
n
t
o
 
o
u
t
p
u
t
s
.
 
Revisit design decisions as you encounter issues.
 
T
e
s
t
:
A
s
 
y
o
u
 
w
r
i
t
e
 
e
a
c
h
 
e
l
e
m
e
n
t
,
 
t
e
s
t
 
y
o
u
r
 
a
s
s
u
m
p
t
i
o
n
s
 
Much easier to test individual pieces than the whole program!
 
M
a
i
n
t
a
i
n
:
S
h
a
r
i
n
g
 
t
h
e
 
c
o
d
e
,
 
d
o
c
u
m
e
n
t
i
n
g
,
 
u
s
e
 
v
e
r
s
i
o
n
 
c
o
n
t
r
o
l
,
 
i
d
e
n
t
i
f
y
 
T
O
D
O
s
 
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
I
M
P
L
E
M
E
N
T
 
Top-down approach
 
Start at the outer-most level, and mock-up inner pieces.
 
 
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
I
M
P
L
E
M
E
N
T
inputFile
 
= DSS.open(…)
configFile = open(…)
results = list()
for configRow in configFile.readlines():
    resultsRow = processRow(configRow, inputFile)
    results.append(resultsRow)
 
# mock implementation
def processRow(config, dssfile):
    return True
 
Bottom-up approach
 
Start with the inner most-level and mock-up the framework
that runs it.  Or use an interpreter to run and test.
 
Implement functions to perform the most basic calculations
first, slowly wrap in higher level functionality.
 
 
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
I
M
P
L
E
M
E
N
T
def processRow(config, dssfile):
    ts = dssfile.read(config[“pathname”])
    values = dict()
    percentiles = config[“percentiles”].split(“;”)
    for perc in percentiles
:
 
values[formatPerc(perc)] = computePercentile(ts, perc)
    return values
 
# interactively now:
>>> testFile = DSS.open(“C:/…/testingData.dss”)
>>> testRow = {“percentiles”=“50;75;90;95;99”, …}
>>> processRow(testRow, testFile)
{“99%”: 5192, “95%”: 4910, “90%”: 3615, … }
 
Approaches:
 
“In-situ” testing:  Manually test the code on real/example data and check the results
-
Adding ‘print statement debugging’ or logging
-
Create examples to test/break code.
 
Automated testing: Implement code that tests your code
-
Unit testing (testing small pieces)
-
Integration testing (testing all the pieces work together)
-
Testing frameworks – allows you to declare expected outcomes for inputs
 
Test-Driven Design (TDD): invert the writing and testing steps:
 
1. write tests for the specifications
 
2. implement code until tests pass
 
Regression testing: when a bug is identified, add a test for that bug!
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
T
E
S
T
 
Storing the script / Version Control:
-
Eternal questions: What’s the current version of the script?  What version are you using?
What changed?  Did I fix that bug yet?
 
Documentation:
-
Code comments
-
API documentation in code (JavaDoc, Sphinx, Doxygen)
-
External “readme” files / manual / user guide
-
Demo datasets or example scripts (for libraries)
-
Document dependencies for users to get started.
 
Debugging and Support:
-
Contact information!
-
Issue tracking systems
 
S
C
R
I
P
T
 
L
I
F
E
C
Y
C
L
E
:
 
M
A
I
N
T
A
I
N
 
Plan your program (or changes) 
before 
you start writing code.
 
Make use of libraries/modules/packages
 – steal shamelessly!  
(HEC API – Day 1/2 lectures)
 
“Modularize” your code – smaller functions and objects 
(Day 1/2 workshops)
 
Use an IDE 
(Eclipse, VS Code, IntelliJ, others)
-
Organize files into a project
-
Debugging features
-
Auto-complete and error checking
-
Refactoring
-
Integration with version control
 
Use Version Control system  
(Git/GitHub – Thursday)
 
S
O
M
E
 
B
E
S
T
 
P
R
A
C
T
I
C
E
S
Slide Note
Embed
Share

Explore the process of moving from an idea to implementing a script, including outlining best practices, considering factors before starting, and understanding the script lifecycle with a focus on design, writing, testing, and maintenance. Discover the importance of writing code for automation, consistency, time-savings, and capability enhancement. Dive into the script lifecycle's four steps of design, implementation, testing, and maintenance to effectively create and manage scripts.


Uploaded on Mar 26, 2024 | 2 Views


Download Presentation

Please find below an Image/Link to download the presentation.

The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. Download presentation by click this link. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.

E N D

Presentation Transcript


  1. BUILDING A SCRIPT Evan Heisman, PE USACE IWR-HEC 21 August 2023

  2. 2 OBJECTIVES How do I go from an idea to implementation? Steps to think through the scripting process Outline some best practices

  3. 3 OUTLINE Before you start Why write code? Script lifecycle: - Designing a script - Writing a script - Testing a script - Maintaining a script Some best practices

  4. 4 BEFORE YOU START What s the first question you should ask? Should you write this code?

  5. 5 SHOULD YOU WRITE THIS CODE? Some factors to consider: - How often do we need to run this code? - Development time < expected time From a 1970 s IBM training document - Will the scripted solution do better? - How will you validate/test the code? - Who will maintain the code? - Who / what will pay for it?

  6. 6 WHY WRITE CODE? - Automation: - Repeatability of a task - Consistency between several tasks - Time-savings to users, labor savings to organization - Adding capabilities: - Some tasks are impossible to do by hand or with off-the-shelf solutions - Extending or customizing existing programs.

  7. 7 SCRIPT LIFECYCLE: FOUR STEPS design maintain implement test

  8. 8 SCRIPT LIFECYCLE: DESIGN Document requirements / specifications! - Inputs - Calculations Performed - Outputs Break the problem into elements Define a minimum viable product (MVP) Add more features after MVP is done Iterate through the cycle for each part of the design Specifications should inform testing

  9. 9 SCRIPT LIFECYCLE: IMPLEMENT Implement in small pieces, following the four steps for each: Design, implement, test, maintain Design: Write pseudo-code to get a picture of the algorithm; Identify the inputs, computations, and outputs at each step Implement: Translate pseudo-code into specifics, figure out steps to transform inputs into outputs. Revisit design decisions as you encounter issues. Test: As you write each element, test your assumptions Much easier to test individual pieces than the whole program! Maintain: Sharing the code, documenting, use version control, identify TODOs

  10. 10 SCRIPT LIFECYCLE: IMPLEMENT Top-down approach Start at the outer-most level, and mock-up inner pieces. inputFile= DSS.open( ) configFile = open( ) results = list() for configRow in configFile.readlines(): resultsRow = processRow(configRow, inputFile) results.append(resultsRow) # mock implementation def processRow(config, dssfile): return True

  11. 11 SCRIPT LIFECYCLE: IMPLEMENT Bottom-up approach Start with the inner most-level and mock-up the framework that runs it. Or use an interpreter to run and test. Implement functions to perform the most basic calculations first, slowly wrap in higher level functionality. def processRow(config, dssfile): ts = dssfile.read(config[ pathname ]) values = dict() percentiles = config[ percentiles ].split( ; ) for perc in percentiles: values[formatPerc(perc)] = computePercentile(ts, perc) return values # interactively now: >>> testFile = DSS.open( C:/ /testingData.dss ) >>> testRow = { percentiles = 50;75;90;95;99 , } >>> processRow(testRow, testFile) { 99% : 5192, 95% : 4910, 90% : 3615, }

  12. 12 SCRIPT LIFECYCLE: TEST Approaches: In-situ testing: Manually test the code on real/example data and check the results - Adding print statement debugging or logging - Create examples to test/break code. Automated testing: Implement code that tests your code - Unit testing (testing small pieces) - Integration testing (testing all the pieces work together) - Testing frameworks allows you to declare expected outcomes for inputs Test-Driven Design (TDD): invert the writing and testing steps: 1. write tests for the specifications 2. implement code until tests pass Regression testing: when a bug is identified, add a test for that bug!

  13. 13 SCRIPT LIFECYCLE: MAINTAIN Storing the script / Version Control: - Eternal questions: What s the current version of the script? What version are you using? What changed? Did I fix that bug yet? Documentation: - Code comments - API documentation in code (JavaDoc, Sphinx, Doxygen) - External readme files / manual / user guide - Demo datasets or example scripts (for libraries) - Document dependencies for users to get started. Debugging and Support: - Contact information! - Issue tracking systems

  14. 14 SOME BEST PRACTICES Plan your program (or changes) before you start writing code. Make use of libraries/modules/packages steal shamelessly! (HEC API Day 1/2 lectures) Modularize your code smaller functions and objects (Day 1/2 workshops) Use an IDE (Eclipse, VS Code, IntelliJ, others) - Organize files into a project - Debugging features - Auto-complete and error checking - Refactoring - Integration with version control Use Version Control system (Git/GitHub Thursday)

More Related Content

giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#