Bin
2025-12-16 9e0b2ba2c317b1a86212f24cbae3195ad1f3dbfa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
Feature("Readonly Annotation");
 
const imageExamples = new DataTable(["example", "regionName"]);
 
imageExamples.add([require("../../../examples/audio-regions"), "Beat"]);
 
Data(imageExamples).Scenario(
  "Audio Readonly Annotations",
  async ({ I, current, LabelStudio, AtOutliner, AtAudioView }) => {
    I.amOnPage("/");
    const { config, result, data } = current.example;
    const regions = result.filter((r) => {
      return r.type.match("labels");
    });
 
    const params = {
      annotations: [
        {
          id: "test",
          readonly: true,
          result,
        },
      ],
      config,
      data,
    };
 
    LabelStudio.init(params);
 
    await AtAudioView.waitForAudio();
    I.waitTicks(3); // Wait for audio regions to be fully interactive
 
    I.say("Check region is selectable");
    AtOutliner.seeRegions(regions.length);
    AtOutliner.clickRegion(current.regionName);
    I.waitTicks(3); // Wait for region selection to complete
 
    const regionId = regions[0].id;
 
    await AtAudioView.moveRegion(regionId, 100);
 
    I.say("Results are equal after modification attempt");
    await LabelStudio.resultsNotChanged(result);
 
    I.pressKey("Backspace");
    I.say("Results are equal after deletion attempt");
    await LabelStudio.resultsNotChanged(result);
 
    I.say("Can't draw new shape");
    I.pressKey("1");
 
    await AtAudioView.createRegion("audio", 50, 100);
    AtOutliner.seeRegions(regions.length);
  },
);