- 
                Notifications
    You must be signed in to change notification settings 
- Fork 71
Open
Labels
Description
Related project scope(s): partition-view
Bug description
Regarding learnocaml_partition_view.ml, it seems two points would deserve to be improved after fixing #438:
- 
learn-ocaml/src/state/learnocaml_api.ml Lines 370 to 372 in fbf3125 | Partition (token, eid, fid, prof) -> get ~token ["partition"; eid; fid; string_of_int prof] 
 → this basically turnPartition("X-U1O-AB1-1FJ-ZOF", "demo", "times", 30)into an HTTP request to
 http://localhost:8080/partition/demo/times/30?token=X-U1O-AB1-1FJ-ZOF
 → I believe this is an issue if the exercise_id contains a/, e.g.:"fpottier/alpha_beta"
 → the URL should be changed to something like
 http://localhost:8080/partition/fpottier%2Falpha_beta/times/30?token=X-U1O-AB1-1FJ-ZOF
 orhttp://localhost:8080/partition/times/30?id=fpottier/alpha_beta&token=X-U1O-AB1-1FJ-ZOF
 → a bit like the already-existing URLhttp://localhost:8080/partition-view.html?id=demo&function=times&prof=30
 → Fortunately, changing this wouldn't impact thelearn-ocaml-client-related backward-compatibility claim:
 learn-ocaml/src/state/learnocaml_api.mli Lines 70 to 79 in fbf3125 Regarding the inevitable extensions of the API: - make sure we only add constructors to this [request] type, - and that their semantics does not change (or at least in a backward-compatible way; see PR https://github.com/ocaml-sf/learn-ocaml/pull/397 for a counter-example); - but if a given entrypoint would need to be removed, add a [Compat.Upto] constraint (*<*) instead. *) 
- 
let _win = window_open ("/student-view.html?token="^tok) "_blank" in 
 → the "BASE_URL" should be prepended, similarly to:
 learn-ocaml/static/partition-view.html Line 36 in 5ebb02d document.getElementById('chamo-img').src = learnocaml_config.baseUrl + '/icons/tryocaml_loading_' + n + '.gif'; 
 (Note to myself: this line oflearnocaml_description_main.mlis also impacted ↓)
 (Printf.sprintf "/description/%s#%s=%s" 
Current configuration
- OS name (and version): GNU/Linux
- Browser name (and version): Firefox
- learn-ocaml --version: 0.13.1