Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Feature:RainbowGrades] Display RainbowGrades version #56

Merged
merged 13 commits into from
Jun 26, 2024
11 changes: 8 additions & 3 deletions MakefileHelper
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
.PHONY: default pull push all compile overall section lab hw test quiz final zone clean src_clean remove_json_comments
.PHONY: default pull push all compile overall section lab hw test quiz final zone clean src_clean remove_json_comments version

default: overall

Expand Down Expand Up @@ -26,6 +26,9 @@ endif

nlohmann_json_dir=${RAINBOW_GRADES_DIRECTORY}/../vendor/nlohmann/json

export RAINBOW_GRADES_DIRECTORY
export REPORTS_DIRECTORY

${nlohmann_json_dir}:
mkdir -p ${nlohmann_json_dir}
wget https://github.com/nlohmann/json/releases/download/v3.1.2/include.zip -O ${RAINBOW_GRADES_DIRECTORY}/../vendor/nlohmann_json.zip
Expand Down Expand Up @@ -75,6 +78,8 @@ endif

json_include = -I${nlohmann_json_dir}/include/

version:
python3 ${RAINBOW_GRADES_DIRECTORY}/track_Rainbow_version.py

remove_json_comments: customization.json
cpp -xc++ $< | sed -e '/^#/d' > customization_no_comments.json
Expand All @@ -93,12 +98,12 @@ process_grades.out: \
individual_summary_html all_students_summary_csv all_students_summary_html:
mkdir -p $@

compile: remove_json_comments process_grades.out individual_summary_html all_students_summary_html all_students_summary_csv
compile: remove_json_comments version process_grades.out individual_summary_html all_students_summary_html all_students_summary_csv

clean:
rm -rf *~ *.dSYM
rm -f process_grades.out
rm -f customization_no_comments.json files_json.txt
rm -f customization_no_comments.json files_json.txt RG_version.json

src_clean: clean
rm -f ${json_syntax_checker.py}
Expand Down
3 changes: 2 additions & 1 deletion main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,11 +37,12 @@ std::vector<std::string> OMIT_SECTION_FROM_STATS;
std::string OUTPUT_FILE = "./output.html";
std::string OUTPUT_CSV_FILE = "./output.csv";
std::string CUSTOMIZATION_FILE = "./customization_no_comments.json";
std::string RG_VERSION_FILE = "./RG_version.json";

std::string RAW_DATA_DIRECTORY = "./raw_data/all_grades/";
std::string INDIVIDUAL_FILES_OUTPUT_DIRECTORY = "./individual_summary_html/";
std::string ALL_STUDENTS_OUTPUT_DIRECTORY = "./all_students_summary_html/";
std::string ALL_STUDENTS_OUTPUT_DIRECTORY_CSV = "./all_students_summary_csv/";
std::string ALL_STUDENTS_OUTPUT_DIRECTORY_CSV = "./all_students_summary_csv/";

nlohmann::json GLOBAL_CUSTOMIZATION_JSON;

Expand Down
31 changes: 31 additions & 0 deletions output.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@

extern std::string OUTPUT_FILE;
extern std::string OUTPUT_CSV_FILE;
extern std::string RG_VERSION_FILE;

extern std::string ALL_STUDENTS_OUTPUT_DIRECTORY;
extern std::string ALL_STUDENTS_OUTPUT_DIRECTORY_CSV;

Expand Down Expand Up @@ -1389,5 +1391,34 @@ void end_table(std::ofstream &ostr, bool for_instructor, Student *s) {

}

// RAINBOW GRADE VERSION DISPLAY
std::ifstream istr(RG_VERSION_FILE.c_str());
assert (istr.good());
nlohmann::json j = nlohmann::json::parse(istr);
// current_commit_hash_rg (Full hash) is not used, parsing just for possible future use
nlohmann::json current_commit_hash_rg = j["installed_commit_rg"];
nlohmann::json current_short_commit_hash_rg = j["short_installed_commit_rg"];
nlohmann::json current_git_tag_rg = j["most_recent_git_tag_rg"];

// Remove double quotation
std::string rainbow_short_hash = current_short_commit_hash_rg;
std::string rainbow_git_tag = current_git_tag_rg;
rainbow_git_tag.erase(std::remove(rainbow_git_tag.begin(), rainbow_git_tag.end(), '\"'), rainbow_git_tag.end());
rainbow_short_hash.erase(std::remove(rainbow_short_hash.begin(), rainbow_short_hash.end(), '\"'), rainbow_short_hash.end());

std::time_t currentTime = std::time(nullptr);
// Convert the time to the local time struct
std::tm* localTime = std::localtime(&currentTime);
// Extract the current year from the local time struct
int currentYear = localTime->tm_year + 1900;


ostr << "<p>&copy; " << currentYear << " <a href=\"https://submitty.org/instructor/course_settings/rainbow_grades/index\" target=\"_blank\" class=\"black-btn\">Submitty/RainbowGrades</a> <a href=\"https://github.com/Submitty/RainbowGrades/releases/tag/" << rainbow_git_tag
<< "\" target=\"_blank\" title=\"" << rainbow_git_tag << " " << rainbow_short_hash
<< "\" class=\"black-btn\">" << rainbow_git_tag << "</a></p>" << std::endl;




ostr.close();
}
53 changes: 53 additions & 0 deletions track_Rainbow_version.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
#!/usr/bin/env python3

import os
import json
import subprocess

CURRENT_PATH = os.path.dirname(os.path.realpath(__file__))
RG_DIR = os.environ.get('RAINBOW_GRADES_DIRECTORY')
REPORT_DIR = os.environ.get('REPORTS_DIRECTORY')
WORKING_DIRECTORY = "."

if __name__ == "__main__":

json_dir = os.path.join(WORKING_DIRECTORY, "RG_version.json")
output_dict = {}
current_commit_hash_rg = 'unknown'
current_short_commit_hash_rg = 'unknown'
current_git_tag_rg = 'unknown'

try:
#run the command 'git rev-parse HEAD' from the RainbowGrades repository directory
current_commit_hash_rg = subprocess.check_output(['git', 'rev-parse', 'HEAD'], cwd=RG_DIR)
current_commit_hash_rg = current_commit_hash_rg.decode('ascii').strip()
current_short_commit_hash_rg = subprocess.check_output(['git', 'rev-parse', '--short', 'HEAD'], cwd=RG_DIR)
current_short_commit_hash_rg = current_short_commit_hash_rg.decode('ascii').strip()
print("Commit {0} is currently installed on this system.".format(current_commit_hash_rg))
except:
print("ERROR: could not determine commit hash.")
current_commit_hash_rg = 'unknown'

try:
#run the command 'git describe --tag --abbrev=0' from the RainbowGrades repository directory
current_git_tag_rg = subprocess.check_output(['git', 'describe', '--tag', '--abbrev=0'], cwd=RG_DIR)
current_git_tag_rg = current_git_tag_rg.decode('ascii').strip()
print("Tag {0} is the most recent git tag.".format(current_git_tag_rg))
except:
print("ERROR: could not determine current git tag.")
current_git_tag_rg = 'unknown'


#remove newline at the end of the hash and tag and convert them from bytes to ascii.

output_dict["installed_commit_rg"] = current_commit_hash_rg
output_dict["short_installed_commit_rg"] = current_short_commit_hash_rg
output_dict["most_recent_git_tag_rg"] = current_git_tag_rg


try:
#Update rainbow_grades/RG_version.json to reflect the current commit hash.
with open(json_dir, 'w') as outfile:
json.dump(output_dict, outfile, indent=2)
except:
print("ERROR: could not write to {0}".format(json_dir))