liquid_feedback_frontend
annotate db/demodata.lua @ 159:5d797c6706d5
implement quorum display
show the initiative quorum as a small 1px line in bargraph
allow to update your support on the diff page
better linked title in diff page
show absolute quorum numbers in detail pages of issue and initiative
show the initiative quorum as a small 1px line in bargraph
allow to update your support on the diff page
better linked title in diff page
show absolute quorum numbers in detail pages of issue and initiative
author | Daniel Poelzleithner <poelzi@poelzi.org> |
---|---|
date | Sat Oct 09 03:42:48 2010 +0200 (2010-10-09) |
parents | 3bfb2fcf7ab9 |
children |
rev | line source |
---|---|
bsw/jbe@0 | 1 #!/usr/bin/env lua |
bsw/jbe@0 | 2 |
bsw/jbe@0 | 3 member_count = 10000 |
bsw/jbe@0 | 4 area_count = 24 |
bsw/jbe@0 | 5 issue_count = 1000 |
bsw/jbe@0 | 6 policy_count = 3 -- do not change |
bsw/jbe@0 | 7 |
bsw/jbe@0 | 8 function write(...) |
bsw/jbe@0 | 9 io.stdout:write(...) |
bsw/jbe@0 | 10 end |
bsw/jbe@0 | 11 function writeln(...) |
bsw/jbe@0 | 12 write(...) |
bsw/jbe@0 | 13 write("\n") |
bsw/jbe@0 | 14 end |
bsw/jbe@0 | 15 |
bsw/jbe@0 | 16 math.randomseed(os.time()) |
bsw/jbe@0 | 17 |
bsw/jbe@0 | 18 writeln('BEGIN;') |
bsw/jbe@0 | 19 |
bsw/jbe@0 | 20 for i = 2, member_count do |
bsw/jbe@0 | 21 writeln('INSERT INTO "member" ("login", "name", "ident_number") VALUES (', "'testuser", i, "', 'Benutzer #", i, "', 'TEST", i, "');") |
bsw/jbe@0 | 22 end |
bsw/jbe@0 | 23 |
bsw/jbe@0 | 24 for i = 1, member_count do |
bsw/jbe@0 | 25 local is_linked = {} |
bsw/jbe@0 | 26 while math.random(4) > 1 do |
bsw/jbe@0 | 27 local k = math.random(member_count) |
bsw/jbe@0 | 28 if not is_linked[k] then |
bsw/jbe@0 | 29 local public = math.random(2) == 1 and "TRUE" or "FALSE" |
bsw/jbe@0 | 30 writeln('INSERT INTO "contact" ("member_id", "other_member_id", "public") VALUES (', i, ", ", k, ", ", public, ");") |
bsw/jbe@0 | 31 is_linked[k] = true |
bsw/jbe@0 | 32 end |
bsw/jbe@0 | 33 end |
bsw/jbe@0 | 34 end |
bsw/jbe@0 | 35 |
bsw/jbe@0 | 36 for i = 2, area_count do |
bsw/jbe@0 | 37 writeln('INSERT INTO "area" ("name") VALUES (', "'Area #", i, "');") |
bsw/jbe@0 | 38 end |
bsw/jbe@0 | 39 |
bsw/jbe@0 | 40 local memberships = {} |
bsw/jbe@0 | 41 |
bsw/jbe@0 | 42 for i = 1, area_count do |
bsw/jbe@0 | 43 memberships[i] = {} |
bsw/jbe@0 | 44 for j = 1, member_count do |
bsw/jbe@0 | 45 if math.random(4) == 1 then |
bsw/jbe@0 | 46 memberships[i][j] = true |
bsw/jbe@0 | 47 local autoreject = math.random(2) == 1 and "TRUE" or "FALSE" |
bsw/jbe@0 | 48 writeln('INSERT INTO "membership" ("member_id", "area_id", "autoreject") VALUES (', j, ", ", i, ", ", autoreject, ");") |
bsw/jbe@0 | 49 end |
bsw/jbe@0 | 50 end |
bsw/jbe@0 | 51 end |
bsw/jbe@0 | 52 |
bsw/jbe@0 | 53 do |
bsw/jbe@0 | 54 local issue_initiative_count = {} |
bsw/jbe@0 | 55 local initiative_draft_count = {} |
bsw/jbe@0 | 56 local initiative_idx = 1 |
bsw/jbe@0 | 57 local draft_count = 0 |
bsw/jbe@0 | 58 for i = 1, issue_count do |
bsw/jbe@0 | 59 local area = math.random(area_count) |
bsw/jbe@0 | 60 writeln('INSERT INTO "issue" ("area_id", "policy_id") VALUES (', area, ", ", math.random(policy_count), ");") |
bsw/jbe@0 | 61 issue_initiative_count[i] = 1 |
bsw/jbe@0 | 62 while math.random(3) > 1 do |
bsw/jbe@0 | 63 issue_initiative_count[i] = issue_initiative_count[i] + 1 |
bsw/jbe@0 | 64 end |
bsw/jbe@0 | 65 for j = 1, issue_initiative_count[i] do |
bsw/jbe@0 | 66 writeln('INSERT INTO "initiative" ("issue_id", "name") VALUES (', i, ", 'Initiative #", initiative_idx, "');") |
bsw/jbe@0 | 67 initiative_draft_count[i] = 1 |
bsw/jbe@0 | 68 while math.random(4) > 1 do |
bsw/jbe@0 | 69 initiative_draft_count[i] = initiative_draft_count[i] + 1 |
bsw/jbe@0 | 70 end |
bsw/jbe@0 | 71 local initiators = {} |
bsw/jbe@0 | 72 local is_used = {} |
bsw/jbe@0 | 73 repeat |
bsw/jbe@0 | 74 local member = math.random(member_count) |
bsw/jbe@0 | 75 if not is_used[member] then |
bsw/jbe@0 | 76 initiators[#initiators+1] = member |
bsw/jbe@0 | 77 is_used[member] = true |
bsw/jbe@0 | 78 end |
bsw/jbe@0 | 79 until math.random(2) == 1 |
bsw/jbe@0 | 80 for k = 1, initiative_draft_count[i] do |
bsw/jbe@0 | 81 draft_count = draft_count + 1 |
bsw/jbe@0 | 82 writeln('INSERT INTO "draft" ("initiative_id", "author_id", "content") VALUES (', initiative_idx, ", ", initiators[math.random(#initiators)], ", 'Lorem ipsum... (#", draft_count, ")');") |
bsw/jbe@0 | 83 end |
bsw/jbe@0 | 84 for k = 1, #initiators do |
bsw/jbe@0 | 85 local member = math.random(member_count) |
bsw/jbe@0 | 86 writeln('INSERT INTO "initiator" ("member_id", "initiative_id") VALUES (', initiators[k], ", ", initiative_idx, ");") |
bsw/jbe@0 | 87 if math.random(50) > 1 then |
bsw/jbe@0 | 88 writeln('INSERT INTO "supporter" ("member_id", "initiative_id", "draft_id") VALUES (', initiators[k], ", ", initiative_idx, ", ", draft_count - math.random(initiative_draft_count[i]) + 1, ");") |
bsw/jbe@0 | 89 end |
bsw/jbe@0 | 90 end |
bsw/jbe@0 | 91 local probability = math.random(99) + 1 |
bsw/jbe@0 | 92 for k = 1, member_count do |
bsw/jbe@0 | 93 if not is_used[k] and (memberships[area][k] and math.random(probability) <= 4 or math.random(probability) == 1) then |
bsw/jbe@0 | 94 writeln('INSERT INTO "supporter" ("member_id", "initiative_id", "draft_id") VALUES (', k, ", ", initiative_idx, ", ", draft_count - math.random(initiative_draft_count[i]) + 1, ");") |
bsw/jbe@0 | 95 end |
bsw/jbe@0 | 96 end |
bsw/jbe@0 | 97 initiative_idx = initiative_idx + 1 |
bsw/jbe@0 | 98 end |
bsw/jbe@0 | 99 end |
bsw/jbe@0 | 100 end |
bsw/jbe@0 | 101 |
bsw/jbe@0 | 102 writeln('END;') |