CSCI 338: Fall 2024

Software Engineering

CSCI 338: Fall 2024

Syllabus

Term Fall 2024
Course CSCI 338: Software Engineering
Instructor Dr. Sarah Van Wart (she / her)
Prerequisites CSCI 202 and CSCI 235
Time Tu/Th 9:55 AM - 11:35 AM
Zoom Link https://unca-edu.zoom.us/j/91825973279?pwd=1GeaiT1yTpbdIRciGlkipajxSaEHej.1
UNCA Catalog Description CSCI 338 is project-oriented course in which students working in teams complete one or more projects encompassing software design and development. Students will develop their communication skills by writing project requirements, creating and evaluating prototypes, interfacing with end users, and developing and implementing test plans.

Post-Helene Updates

Welcome back! Due to the time lost because of Helene, the following schedule adjustments have been made:

  1. The midterm has been cancelled. There will still be a cumulative final exam, which will count as 30% of your grade.
  2. We will still be meeting synchronously during regularly scheduled class time on Zoom. All class meetings will be recorded.
  3. I will still be taking attendance in order to foster participation and active learning.
    • If you are not able to attend the class synchronously, you can still earn full credit for “attendance” completing a 1-page reflection that you will submit to Sarah weekly by email (svanwart@unca.edu). Your reflection should answer at least three of the discussion questions listed under the current topic, which are posted on the schedule.

Acknowledgements

This course was designed in partnership with Dr. Semmy Purewal. We are very grateful to Semmy for bringing his industry knowledge to this class and helping the next generation of software engineers here at UNC Asheville learn from it.

About the Course

Welcome to CSCI 338! Taking this course gives you the opportunity to work on a collaborative software development project while learning some of the tools, methods, and processes that are widely used in industry. We will be using some specific programming languages and libraries to explore various “big ideas” in software engineering. That said, the focus of this course is on the processes and tools that will enable you to build software that is scalable and maintainable over time (versus learning particular languages / libraries). Drawing from Software Engineering at Google (one of the books we will use in this course), we will explore three categories of considerations:

  1. Culture – How people on teams can work well together; document and share knowledge; prioritize technical, social, and business goals; cultivate a curious, open, and critical perspective on their work; and measure the benefits and costs of technical decisions.
  2. Process – How to actually go about writing code, including coming up with style guides and coding conventions, doing code reviews, documenting your code, writing tests, deprecating features, and breaking down ideas into concrete features and tasks (so that you can make clear and manageable progress).
  3. Tools – Using different software tools to improve how your team manages their codebase. This includes tools for version control, building and compiling your system (particularly important for larger systems), managing dependencies, and ensuring that you are continuously integrating and deploying code changes.

By the end of this course, our hope is that you will view software engineering as set of tools and strategies for managing uncertainty, change, and competing priorities – versus a fixed list of rules that you follow religiously. How software development proceeds depends on your goals, the constraints you are under, and the information and tools you have at your disposal. Given this, the more holistically you think about evaluating different trade-offs and choices, the more effective you will become.

Course Format

The course format includes a mix of assigned readings, lectures, labs, projects, quizzes, and exams. We will generally try to use our Tuesday class time to discuss a “big idea” in software engineering, and our Thursday class time to complete hands-on labs. It is your responsibility to keep up-to-date on class material and announcements, as the schedule is subject to change. This includes material presented and announcements made in class, via email, or on Moodle.

Class Participation

Class meetings will be in person. Most class sessions have accompanying readings, which you will be expected to complete before class. Please do your best to be physically and mentally present, and to share your knowledge and experience with one another.

Projects

Over the course of the semester, you will be working with your classmates on a collaborative software development project. During the first half of the semester, you will be assigned 1-2 features that you will need to implement and deploy to the class’s shared codebase (individual assignments). During the second half of the semester, you will be working with one or more of your classmates to design, build, and test a feature that you come up with as a team.

Our hope is that the experience will help you develop more perspective around how software teams organize their work, make decisions, onboard new developers, introduce new features, etc.

Note: I am still figuring out how we will be organizing the projects. The current plan (described above) may change.

Labs

Labs are intended to be completed during class on Thursdays (unless otherwise specified), so that we can help you with any questions (or configuration issues) you make have. Each lab is designed to give you practice with a tool, technique, or workflow relevant to building collaborative software.

Exams

There will also be a midterm and a final exam to assess your understanding of some of the methods we are learning about (e.g., version control, tradeoffs, CI/CD, managing trade-offs, navigating constraints and uncertainty, dependency management, etc.).

Course Expectations

Course Materials & Resources

Books

We will be reading selected chapters from Software Engineering at Google. There is a free copy of the book online, or you can order a hardcopy.

Software

This course will utilize many different software packages, libraries, and tools (all free), including the ones listed below. You will probably need around 5GB of disk space to run these programs. Installing and configuring programming software can be a hassle, but it is part of the process of developing your working computing knowledge. We will help you.

Other Course Resources

We will also be compiling a list of cheatsheets, online tutorials, and documentation pages on the course Readings and Resources page.

Acknowledgements

These course materials were developed collaboratively by Sarah Van Wart and Semmy Purewal.

Grading

Your course grade is calculated based on projects, labs, exams, and attendance / participation:

Labs 30%
Projects 30%
Attendance & Participation 10%
Midterm Exam 15%
Final Exam 15%

Labs

Labs will be graded according to the following scale (from 0-3 points):

0pts Not attempted Assignment not submitted.
1pt Check Minus Assignment attempted but less than half of it was completed correctly.
2pts Check Most of the assignment was completed.
3pts Check Plus Assignment fully completed and works as expected.

Late labs will not be accepted.

Projects

projects involve building part of a larger system, and will be graded according to a rubric. We will be using a code review workflow to assess you. Here is how the process will work:

Code Reviews

  1. You will submit your work as a series of pull requests (PR) on or before the due date.
  2. I will do a code review and either ask for changes or accept your changes.
    • If your PR is accepted, you’re done and will receive full credit for your work.
    • Otherwise, you will need to implement the requested changes and re-submit before the deadline.

Code Review Resubmissions and Late Work

Participation

In this class, participation is defined as:

  1. [5%] Attendance – “Half of life is just showing up.”
  2. [5%] Engaging with the course ideas and with your peers, including completing the readings and participating in the discussions and activities, and performance on the quizzes.

We will take attendance. You may miss two class sessions – no questions asked – without a grade penalty. Any additional absences (beyond your two “freebies”) will impact your participation grade (and more to the point, your capacity to productively engage with the class).

Exams

Exams will be graded according to how thoroughly you answer the questions and drawing from the principles and readings covered of the course.

Course Policies

General

Academic Honesty

In the past, there have been a few unfortunate instances in which students have presented work other than their own. Here are some guidelines to help you understand what is and is not appropriate. Please do no hesitate to contact the instructors if you have any questions about these guidelines.

Labs

Helping other students with their in-class labs is allowed and encouraged, but each student should type their own solution unless otherwise specified in the lab instructions.

Projects

Using Outside Tools and Materials

In this class, we encourage you to explore the broader Internet for tutorials, code samples, new coding techniques, libraries, etc. That said, you must acknowledge all sources contributing to your work. If you receive any assistance from any source (Internet, peer, social media, ChatGPT, etc.), please describe your source and that source’s contribution(s). If you have any questions about this, please don’t hesitate to contact the instructors.

Students violating the academic honesty policy on an assignment will receive a grade of 0 on that assignment for the first offense, and will receive a grade of “F” in the course for the second offense. This will apply to all students involved in the violation, including both the source student and the copying student. It is your responsibility to ensure that your work is not used by other students.

All cases of academic dishonesty will be reported to the Assistant Provost.

ChatGPT Policy (adapted from Boston University)

Students shall…

I (Sarah) shall…

This policy recognizes that…

Class Cancellation Policy

If a class meeting is canceled or due dates are moved due to inclement weather or any other reason, we will inform you via campus email (ending with unca.edu).

University Policies

Office of Accessibility & Academic Accommodations

UNC Asheville is committed to providing an inclusive experience, accessible learning environments and equal opportunity to individuals with disabilities in accordance with the Americans with Disabilities Act (ADA) and Section 504 of the Rehabilitation Act.

If you are a student experiencing barriers to access or full participation in this course on the basis of a disability, contact the Office of Accessibility to apply for reasonable accommodations and discuss available resources. You may contact the Office of Accessibility at academicaccess@unca.edu or 828-251-6292.

Students are responsible for discussing their Letter of Accommodations (LOA) with their faculty. Students and faculty are encouraged to discuss the LOA as early in the semester as possible to allow for extended access to accommodations. However, students may disclose a disability at any point in the semester. Accommodations are not retroactive and are activated when the LOA is discussed.

Promoting Gender Equity, Addressing Sexual Misconduct

UNC Asheville is dedicated to cultivating and maintaining a safe, respectful, and inclusive environment, free from harassment and discrimination. We strive to ensure that all have equal access to the educational and employment opportunities the University provides. If you or someone you know has been affected by sex-based harassment or sexual misconduct, including sexual assault, dating or domestic violence, or stalking, please know that help and support are available. UNC Asheville strongly encourages all members of the community to take action, seek support, and report incidents of sexual harassment to the Title IX Office. You may contact the Title IX Office or Heather Lindkvist, the Title IX Coordinator, directly at 828.232.5658 or via titleix@unca.edu or learn more by visiting the Title IX website.

As a faculty member, I am a “responsible employee” and private resource. This means that if you share any information or discuss an incident with me regarding sexual or gender-based harassment, I must disclose this information to the Title IX Coordinator. Our goal is to ensure you are aware of the range of options available to you and have access to the resources you may need.

If you wish to speak with a confidential resource, contact University Health and Counseling Services at 828.251.6520. Off-campus confidential resources include Our Voice (24-Hour Hotline at 828.255.7576) and Helpmate (24-Hour Hotline at 828.254.0516).

Academic Alerts

Faculty at UNC Asheville have access to an Academic Alert system. The purpose of this system is to support communication with students about their progress in courses, especially if there are concerns (e.g., academic difficulty, attendance problems). Professors use the Alert system because they are invested in their students’ success. Entering an academic alert is a great way to supplement open conversations between instructors and students about how students can improve their academic performance.

When a faculty member submits an alert that expresses a concern, the student receives outreach from their academic advisor or the team in the Office of Academic Advising. Students are no longer receiving automated notification emails when an alert is submitted. It is in the student’s best interest to address the alert quickly, as students who do so are more likely to earn credit for the course. Questions about the Academic Alert system can be directed to Anne Marie Roberts (amrober1@unca.edu) in the Academic Success Center.

Mental Health Support

As a student, you may experience a range of challenges that can interfere with learning, such as stressful life events, experiences of anxiety and/or depression, self-harm, substance use, and/or unusual difficulty with ordinary life activities. The increased stress of school can also make existing mental health struggles more difficult to manage. Support is available and treatment can help. Learn more about the confidential mental health services UNC Asheville provides to support student success at https://www.unca.edu/life/health-counseling/.

The Health and Counseling Center is located at 118 W.T. Weaver Boulevard. Appointments can be made by calling 828-251-6520. A UNC Asheville counselor on call is available after 5 p.m. and on weekends; the counselor on call can be accessed by calling the UNCA Campus Police dispatcher at 828-251-6710. Additionally available after hours and on weekends, call the Bulldog Health Link at 1-888-267-3675, where you can get immediate support for mental health, medical consultation, concern for a friend, and/or community resources. In case of an emergency, you can also call RHA’s Mental Health Mobile Crisis Unit at 1-888-573-1006.