For debugging on Azure, see CloudODS Debugging
- .NET 8.0 SDK
- Either:
- Visual Studio 2022, or
- Visual Studio 2022 Build Tools (install the ".NET Build Tools" component)
- Clone this repository locally
- To work with the official Ed-Fi Docker solution, also clone the Docker repository.
- Start the registry editor (regedit.exe)
- Navigate to
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\FileSystem
- Double click LongPathsEnabled
- Set to 1 and click OK
The PowerShell script build.ps1
in the root directory contains functions for
running standard build operations at the command line . This script assumes that
.NET 8.0 SDK or newer is installed. Other dependencies tools are downloaded
as needed (nuget, nunit).
Available commands:
.\build.ps1 clean
runs the MSBuildclean
task.\build.ps1 build
runs the MSBuildbuild
task with several implicit steps, including NuGet restore and temporary injection of version numbers into the AssemblyInfo.cs files..\build.ps1 unittest
executes NUnit tests in projects named*.UnitTest
, which do not connect to a database..\build.ps1 integrationtest
executes NUnit tests in projects named*.Test
, which connect to a database (does not include the Azure integration test project)..\build.ps1 buildandtest
executes the Build, UnitTest, and IntegrationTest commands..\build.ps1 package
builds pre-release and release NuGet packages for the Admin App web application..\build.ps1 push
uploads a NuGet package to the NuGet feed..\build.ps1 run
launches the Admin App from the build script. The LaunchProfile parameter is required for running Admin App. Valid values include 'mssql-district' , 'mssql-shared', 'mssql-year', 'pg-district', 'pg-shared' and 'pg-year'
Note: IsLocalBuild switch is expected when user try to run build.ps1 locally.
Review the parameters at the top of build.ps1
for additional command line
arguments.
See .teamcity/readme.md for information on how to use the TeamCity build configurations.
To run the ODS/API locally (not in Docker), follow the Getting Started instructions for the desired version of the Operational Data Store (ODS) and API. NOTE: the current Admin App code supports ODS/API for Tech Suite 3, version 3.4, 5.0.1, and 5.1.0
Initially, the ODS/API will be set to run in Sandbox Mode, in which case Admin App is not needed. Admin App supports the three "production" operation modes: Shared Instance, Year-Specific, and District-Specific. The instructions below will aid in running in each of these three modes.
Admin App works with both SQL Server and PostgreSQL. The non-Docker notes describe working with SQL Server, whereas the Docker instructions use PostgreSQL.
-
Get started with the ODS/API until the point where you are ready to have the ODS/API running in Visual Studio.
-
Change the ODS/API
web.config
(v3.x) orappsettings.json
(v5.x) to run in "SharedInstance" mode and ensure that the ODS connection string points to databaseEdFi_{0}
. At runtime, the software will substitute "Ods" for the replacement token{0}
. -
Install the AdminApp database support by running the following command in a PowerShell window:
# From AdminApp clone directory cd eng .\run-dbup-migrations.ps1
⚠️ you may wish to review the default configuration at the top of this script to ensure that it is appropriate for your situation. -
Run the build script and exercise tests to verify your setup:
.\build.ps1 buildandtest
-
Run Admin App from Visual Studio, choosing either the "Shared Instance (SQL Server)" profile (uses IIS Express) or "mssql-shared" profile (runs the Kestrel built-in web server).
To reset the databases so that you start from a clean slate, re-run initdev
and return to step 3 above.
-
Stop the ODS/API and/or Admin App if running in Visual Studio.
-
Change the ODS/API
web.config
(v3.x) orappsettings.json
(v5.x) to run in "YearSpecific" mode and ensure that the ODS connection string points to databaseEdFi_{0}
. At runtime, the software will substitute "Ods_yyyy" for the replacement token{0}
, where "yyyy" is the four digit year of a given year instance database. -
Re-run
initdev
with the following command, changing the years as desired:initdev -InstallType YearSpecific -OdsTokens '2020;2021'
-
Install the AdminApp database support by running the following command in a PowerShell window:
# From AdminApp clone directory cd eng .\run-dbup-migrations.ps1
⚠️ you may wish to review the default configuration at the top of this script to ensure that it is appropriate for your situation. -
Run the build script and exercise tests to verify your setup:
.\build.ps1 buildandtest
-
Run Admin App from Visual Studio, choosing either the "Year Specific (SQL Server)" profile (uses IIS Express) or "mssql-year" profile (runs the Kestrel built-in web server).
To reset the databases so that you start from a clean slate, return to step 3 above.
-
Stop the ODS/API and/or Admin App if running in Visual Studio.
-
Change the ODS/API
web.config
(v3.x) orappsettings.json
(v5.x) to run in "DistrictSpecific" mode and ensure that the ODS connection string points to databaseEdFi_{0}
. At runtime, the software will substitute "Ods_ddddd" for the replacement token{0}
, where "ddddd" is the numeric identifier of a given district instance database. -
Re-run
initdev
with the following command:initdev -InstallType DistrictSpecific -OdsTokens '255901;255902;255903;255904;255905'
-
Install the AdminApp database support by running the following command in a PowerShell window:
# From AdminApp clone directory cd eng .\run-dbup-migrations.ps1
⚠️ you may wish to review the default configuration at the top of this script to ensure that it is appropriate for your situation. -
Run the build script and exercise tests to verify your setup:
.\build.ps1 buildandtest
-
Run Admin App from Visual Studio, choosing either the "District Specific (SQL Server)" profile (uses IIS Express) or "mssql-district" profile (runs the Kestrel built-in web server).
To reset the databases so that you start from a clean slate, return to step 3 above.
These instructions are for running AdminApp from Visual Studio, connecting to the ODS/API running in Docker:
-
Follow the README instructions for configuring and running the ODS/API in Docker, except you should run the "local debug" compose file instead of the default one, so that you are not starting Admin App itself inside of Docker.
# From the Docker clone directory docker compose -f compose-shared-instance-for-local-debug.yml up -d
-
Generate a 256 bit AES encryption key and paste it into the
appSettings.Docker-SharedInstance.json
file.⚠️ do not commit your modified file into source control. You can generate a key using a PowerShell script in theeng
directory:# From AdminApp clone directory Import-Module ./eng/key-management.psm1 New-AESKey
-
In the connection strings for this same file, adjust the default Host, Port, Username, and Password as required for your Docker configuration.
-
Run Admin App, selecting the "Shared Instance (Docker-Postgres)" profile.
Whereas the instructions above allow you to run Admin App from Visual Studio, pointing to the ODS/API in Docker, the instructions below are for injecting the locally-built Admin App into a Docker container so that the freshly-compiled DLLs are what runs inside of Docker.
-
Follow the README instructions for configuring and running the ODS/API in Docker. This time, you will want to run Docker compose using
compose-shared-instance-env-build.yml
:docker compose -f compose-shared-instance-env-build.yml up -d
-
Open a PowerShell prompt and change to the AdminApp clone directory.
-
Review and edit, if necessary, the parameters in file
BuildDockerDevelopment.ps1
. -
Run following command for quick build and deploy/ copy over the latest files to an existing docker container:
# From AdminApp clone directory .\BuildDockerDevelopment.ps1