PyKubeGrader 0.2.2__py3-none-any.whl → 0.2.4__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: PyKubeGrader
3
- Version: 0.2.2
3
+ Version: 0.2.4
4
4
  Summary: Add a short description here!
5
5
  Home-page: https://github.com/pyscaffold/pyscaffold/
6
6
  Author: jagar2
@@ -1,17 +1,17 @@
1
1
  pykubegrader/__init__.py,sha256=AoAkdfIjDDZGWLlsIRENNq06L9h46kDGBIE8vRmsCfg,311
2
- pykubegrader/initialize.py,sha256=t3iSdeIcndfY8LoHBVUEZfTW6sUWHyeFLirKo4GwSQE,3328
3
- pykubegrader/telemetry.py,sha256=bgBWt9B3zqbfV2xWKDZKg41ZEBaF6X43O74do1fRylM,5325
2
+ pykubegrader/initialize.py,sha256=lQ80bB4LHDLJXFFl820_mNTFXvXpLT-rEAViBBsEPn0,3568
3
+ pykubegrader/telemetry.py,sha256=yUQkpsR5tPEwzEQ1dKgD-ANsWj2x46v3HCIovhUIO78,5337
4
4
  pykubegrader/utils.py,sha256=T3GYnLnTL9VXjTZNPr00sUgMgobQYsNTGwynMyXdvHk,696
5
5
  pykubegrader/validate.py,sha256=2KLSB3wfFZbBh1NGgmrOV073paKAgrQz4AgA6LmCIj4,11076
6
6
  pykubegrader/build/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
7
7
  pykubegrader/build/api_notebook_builder.py,sha256=FEaTj1fEsPAes7KNrPuhClEvKzLuOL3wG7Hgr7FQc-o,20083
8
- pykubegrader/build/build_folder.py,sha256=uJ4pSokOEQ9OFw0MFNtFJ-IfvCC0knT3EPPPfY74cUQ,70942
8
+ pykubegrader/build/build_folder.py,sha256=MyQ7ncPwiuTZ9PD7Q7al1n1bog4cugH1ew5DEC2NqNM,71700
9
9
  pykubegrader/build/clean_folder.py,sha256=8N0KyL4eXRs0DCw-V_2jR9igtFs_mOFMQufdL6tD-38,1323
10
10
  pykubegrader/graders/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
11
11
  pykubegrader/graders/late_assignments.py,sha256=_2-rA5RqO0BWY9WAQA_mbCxxPKTOiJOl-byD2CYWaE0,1393
12
12
  pykubegrader/log_parser/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
13
- pykubegrader/log_parser/parse.ipynb,sha256=kPTo9gqhDineT7yT56P9xrQP1OKTf6Ro-iR4xlJ-or8,10610
14
- pykubegrader/log_parser/parse.py,sha256=uw8lxWVh0FTaWi-bVmpMBbqwTXIHlJtB9gPc1qKvm4I,7040
13
+ pykubegrader/log_parser/parse.ipynb,sha256=GnEgUmowdN2bZSwwWgxqi43QXaP-syPD2SnHvOGq1vU,11674
14
+ pykubegrader/log_parser/parse.py,sha256=YCs_OCnoxQKsL55MjTZWXBBBsehJL8PIB9ANnC-aE44,7379
15
15
  pykubegrader/widgets/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
16
16
  pykubegrader/widgets/multiple_choice.py,sha256=NjD3-uXSnibpUQ0mO3hRp_O-rynFyl0Dz6IXE4tnCRI,2078
17
17
  pykubegrader/widgets/reading_question.py,sha256=y30_swHwzH8LrT8deWTnxctAAmR8BSxTlXAqMgUrAT4,3031
@@ -24,9 +24,9 @@ pykubegrader/widgets_base/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-
24
24
  pykubegrader/widgets_base/multi_select.py,sha256=Cl0IN21wXLZuFu-zC65aS9tD4jMfzCRJ2DPjHao5_Ak,4044
25
25
  pykubegrader/widgets_base/reading.py,sha256=_vjUPynqmJe_R4vf-7hVhGnQR726S9GL6qT8bflBXBM,5383
26
26
  pykubegrader/widgets_base/select.py,sha256=Fw3uFNOIWo1a3CvlzSx23bvi6bSmA3TqutuRbhD4Dp8,2525
27
- PyKubeGrader-0.2.2.dist-info/LICENSE.txt,sha256=YTp-Ewc8Kems8PJEE27KnBPFnZSxoWvSg7nnknzPyYw,1546
28
- PyKubeGrader-0.2.2.dist-info/METADATA,sha256=HH2a7leI9j-Lf9pcak_eWU8zSiQusCes-5zqZtLQg0A,2729
29
- PyKubeGrader-0.2.2.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
30
- PyKubeGrader-0.2.2.dist-info/entry_points.txt,sha256=UPMdTT46fQwTYJWtrUwIWIbXbwyOPfNQgBFRa0frWzw,138
31
- PyKubeGrader-0.2.2.dist-info/top_level.txt,sha256=e550Klfze6higFxER1V62fnGOcIgiKRbsrl9CC4UdtQ,13
32
- PyKubeGrader-0.2.2.dist-info/RECORD,,
27
+ PyKubeGrader-0.2.4.dist-info/LICENSE.txt,sha256=YTp-Ewc8Kems8PJEE27KnBPFnZSxoWvSg7nnknzPyYw,1546
28
+ PyKubeGrader-0.2.4.dist-info/METADATA,sha256=3Wmq0IVVMvUQVjH_yEoyYkR6MEKs75rg81HPePHCKqo,2729
29
+ PyKubeGrader-0.2.4.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
30
+ PyKubeGrader-0.2.4.dist-info/entry_points.txt,sha256=UPMdTT46fQwTYJWtrUwIWIbXbwyOPfNQgBFRa0frWzw,138
31
+ PyKubeGrader-0.2.4.dist-info/top_level.txt,sha256=e550Klfze6higFxER1V62fnGOcIgiKRbsrl9CC4UdtQ,13
32
+ PyKubeGrader-0.2.4.dist-info/RECORD,,
@@ -190,6 +190,8 @@ class NotebookProcessor:
190
190
  return {
191
191
  "title": title,
192
192
  "description": str(week),
193
+ "week_number": week,
194
+ "assignment_type": assignment_type,
193
195
  "due_date": due_date,
194
196
  "max_score": int(self.assignment_total_points),
195
197
  }
@@ -503,7 +505,7 @@ class NotebookProcessor:
503
505
  NotebookProcessor.add_initialization_code(
504
506
  temp_notebook_path, self.week, self.assignment_type
505
507
  )
506
- NotebookProcessor.replace_temp_in_notebook(
508
+ NotebookProcessor.replace_temp_no_otter(
507
509
  temp_notebook_path, temp_notebook_path
508
510
  )
509
511
  return None, 0
@@ -653,6 +655,22 @@ class NotebookProcessor:
653
655
  return solution_path, question_path
654
656
  else:
655
657
  return None, None
658
+
659
+ @staticmethod
660
+ def replace_temp_no_otter(input_file, output_file):
661
+ # Load the notebook
662
+ with open(input_file, "r", encoding="utf-8") as f:
663
+ notebook = nbformat.read(f, as_version=4)
664
+
665
+ # Iterate through the cells and modify `cell.source`
666
+ for cell in notebook.cells:
667
+ if cell.cell_type == "code": # Only process code cells
668
+ if 'responses = initialize_assignment(' in cell.source:
669
+ cell.source = cell.source.replace('_temp', '')
670
+
671
+ # Save the modified notebook
672
+ with open(output_file, "w", encoding="utf-8") as f:
673
+ nbformat.write(notebook, f)
656
674
 
657
675
  @staticmethod
658
676
  def replace_temp_in_notebook(input_file, output_file):
@@ -677,6 +695,7 @@ class NotebookProcessor:
677
695
  cell["source"] = [
678
696
  line.replace("_temp.ipynb", ".ipynb") for line in cell["source"]
679
697
  ]
698
+
680
699
 
681
700
  # Write the updated notebook to the output file
682
701
  with open(output_file, "w", encoding="utf-8") as f:
@@ -1,3 +1,4 @@
1
+ import hashlib
1
2
  import os
2
3
  import shutil
3
4
  from pathlib import Path
@@ -46,7 +47,7 @@ def initialize_assignment(
46
47
  raise Exception("Setup unsuccessful. Are you on JupyterHub?")
47
48
 
48
49
  try:
49
- seed = hash(jhub_user) % 1000
50
+ seed = username_to_seed(jhub_user) % 1000
50
51
  update_responses(key="seed", value=seed)
51
52
  update_responses(key="week", value=week)
52
53
  update_responses(key="assignment_type", value=assignment_type)
@@ -111,3 +112,10 @@ def move_dotfiles():
111
112
  shutil.copy2(source_file, target_file)
112
113
  except Exception as e:
113
114
  raise Exception(f"Failed to copy {source_file} to {target_file}: {e}")
115
+
116
+
117
+ def username_to_seed(username: str, mod: int = 1000) -> int:
118
+ hash_object = hashlib.sha256(username.encode())
119
+ hash_hex = hash_object.hexdigest()
120
+ hash_int = int(hash_hex, 16)
121
+ return hash_int % mod
@@ -182,6 +182,43 @@
182
182
  "outputs": [],
183
183
  "source": []
184
184
  },
185
+ {
186
+ "cell_type": "code",
187
+ "execution_count": null,
188
+ "metadata": {},
189
+ "outputs": [],
190
+ "source": [
191
+ "student_email = results[\"student_information\"][\"username\"]\n",
192
+ "time_stamp = results[\"student_information\"][\"timestamp\"]\n",
193
+ "assignments_graded = results[\"assignment_information\"].keys()\n",
194
+ "week_num = results[\"week_num\"]\n",
195
+ "assignment_type = results['assignment_type']\n",
196
+ "\n",
197
+ "\n",
198
+ "total_score = 0\n",
199
+ "for assignment in assignments_graded:\n",
200
+ " max_points = results[\"assignment_information\"][assignment][\"max_points\"]\n",
201
+ " total_score = results[\"assignment_information\"][assignment][\"total_score\"]\n",
202
+ "\n"
203
+ ]
204
+ },
205
+ {
206
+ "cell_type": "code",
207
+ "execution_count": null,
208
+ "metadata": {},
209
+ "outputs": [],
210
+ "source": [
211
+ "def extract_score_from_dict(results):\n",
212
+ " student_email = results[\"student_information\"][\"username\"]"
213
+ ]
214
+ },
215
+ {
216
+ "cell_type": "code",
217
+ "execution_count": null,
218
+ "metadata": {},
219
+ "outputs": [],
220
+ "source": []
221
+ },
185
222
  {
186
223
  "cell_type": "code",
187
224
  "execution_count": null,
@@ -166,6 +166,15 @@ class LogParser:
166
166
  """
167
167
  return {
168
168
  "student_information": self.student_info,
169
+ "week": self.week_tag,
170
+ "week_num": (
171
+ int(self.week_tag.split("-")[0].strip().replace("week", ""))
172
+ if self.week_tag
173
+ else None
174
+ ),
175
+ "assignment_type": (
176
+ self.week_tag.split("-")[1].strip() if self.week_tag else None
177
+ ),
169
178
  "assignment_information": {
170
179
  assignment: {
171
180
  "latest_timestamp": data["latest_timestamp"],
pykubegrader/telemetry.py CHANGED
@@ -85,7 +85,7 @@ def log_encrypted(logger: logging.Logger, message: str) -> None:
85
85
 
86
86
 
87
87
  def log_variable(assignment_name, value, info_type) -> None:
88
- timestamp = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
88
+ timestamp = datetime.datetime.now(datetime.UTC).strftime("%Y-%m-%d %H:%M:%S")
89
89
  message = f"{assignment_name}, {info_type}, {value}, {timestamp}"
90
90
  log_encrypted(logger_reduced, message)
91
91