New upstream version 13.3.8
This commit is contained in:
parent
529b513274
commit
c7883f9ba0
6677 changed files with 425729 additions and 86073 deletions
|
@ -27,7 +27,6 @@ rules:
|
|||
- ignore:
|
||||
# https://gitlab.com/gitlab-org/gitlab/issues/38226
|
||||
- '^ee_component/'
|
||||
import/order: off
|
||||
# Disabled for now, to make the airbnb-base 12.1.0 -> 13.1.0 update smoother
|
||||
no-else-return:
|
||||
- error
|
||||
|
|
510
.gitignore
vendored
510
.gitignore
vendored
|
@ -77,7 +77,6 @@ eslint-report.html
|
|||
/locale/**/LC_MESSAGES
|
||||
/locale/**/*.time_stamp
|
||||
/.rspec
|
||||
/.gitlab_pages_secret
|
||||
/.gitlab_smime_key
|
||||
/.gitlab_smime_cert
|
||||
package-lock.json
|
||||
|
@ -95,3 +94,512 @@ webpack-dev-server.json
|
|||
apollo.config.js
|
||||
/tmp/matching_foss_tests.txt
|
||||
ee/changelogs/unreleased-ee
|
||||
|
||||
# Likely anything 2017 was removed in bac4d96dcfc, 381b706559b, or cfae6ec2647
|
||||
db/schema_migrations/2014*
|
||||
db/schema_migrations/2015*
|
||||
db/schema_migrations/2016*
|
||||
db/schema_migrations/2017*
|
||||
|
||||
# Removed in 02ea9bc792b9236ea8854154ea5caef1a03b07b4
|
||||
db/schema_migrations/20171230123729
|
||||
db/schema_migrations/20180101160629
|
||||
db/schema_migrations/20180101160630
|
||||
db/schema_migrations/20180102220145
|
||||
db/schema_migrations/20180103123548
|
||||
db/schema_migrations/20180104131052
|
||||
db/schema_migrations/20180105212544
|
||||
db/schema_migrations/20180109183319
|
||||
db/schema_migrations/20180113220114
|
||||
db/schema_migrations/20180115094742
|
||||
db/schema_migrations/20180115113902
|
||||
db/schema_migrations/20180115201419
|
||||
db/schema_migrations/20180116193854
|
||||
db/schema_migrations/20180119121225
|
||||
db/schema_migrations/20180119135717
|
||||
db/schema_migrations/20180119160751
|
||||
db/schema_migrations/20180122154930
|
||||
db/schema_migrations/20180122162010
|
||||
db/schema_migrations/20180125214301
|
||||
db/schema_migrations/20180129193323
|
||||
db/schema_migrations/20180201102129
|
||||
db/schema_migrations/20180201110056
|
||||
db/schema_migrations/20180201145907
|
||||
db/schema_migrations/20180204200836
|
||||
db/schema_migrations/20180206200543
|
||||
db/schema_migrations/20180208183958
|
||||
db/schema_migrations/20180209115333
|
||||
db/schema_migrations/20180209165249
|
||||
db/schema_migrations/20180212030105
|
||||
db/schema_migrations/20180212101828
|
||||
db/schema_migrations/20180212101928
|
||||
db/schema_migrations/20180212102028
|
||||
db/schema_migrations/20180213131630
|
||||
db/schema_migrations/20180214093516
|
||||
db/schema_migrations/20180214155405
|
||||
db/schema_migrations/20180215181245
|
||||
db/schema_migrations/20180216120000
|
||||
db/schema_migrations/20180216120010
|
||||
db/schema_migrations/20180216120020
|
||||
db/schema_migrations/20180216120030
|
||||
db/schema_migrations/20180216120040
|
||||
db/schema_migrations/20180216120050
|
||||
db/schema_migrations/20180216121020
|
||||
db/schema_migrations/20180216121030
|
||||
db/schema_migrations/20180219153455
|
||||
db/schema_migrations/20180220150310
|
||||
db/schema_migrations/20180221151752
|
||||
db/schema_migrations/20180222043024
|
||||
db/schema_migrations/20180223120443
|
||||
db/schema_migrations/20180223124427
|
||||
db/schema_migrations/20180223144945
|
||||
db/schema_migrations/20180226050030
|
||||
db/schema_migrations/20180227182112
|
||||
db/schema_migrations/20180228172924
|
||||
db/schema_migrations/20180301010859
|
||||
db/schema_migrations/20180301084653
|
||||
db/schema_migrations/20180302152117
|
||||
db/schema_migrations/20180305095250
|
||||
db/schema_migrations/20180305100050
|
||||
db/schema_migrations/20180305144721
|
||||
db/schema_migrations/20180306074045
|
||||
db/schema_migrations/20180306134842
|
||||
db/schema_migrations/20180306164012
|
||||
db/schema_migrations/20180307012445
|
||||
db/schema_migrations/20180308052825
|
||||
db/schema_migrations/20180308125206
|
||||
db/schema_migrations/20180309121820
|
||||
db/schema_migrations/20180309160427
|
||||
db/schema_migrations/20180314100728
|
||||
db/schema_migrations/20180314145917
|
||||
db/schema_migrations/20180315160435
|
||||
db/schema_migrations/20180319190020
|
||||
db/schema_migrations/20180320182229
|
||||
db/schema_migrations/20180323150945
|
||||
db/schema_migrations/20180326202229
|
||||
db/schema_migrations/20180327101207
|
||||
db/schema_migrations/20180330121048
|
||||
db/schema_migrations/20180403035759
|
||||
db/schema_migrations/20180405101928
|
||||
db/schema_migrations/20180405142733
|
||||
db/schema_migrations/20180408143354
|
||||
db/schema_migrations/20180408143355
|
||||
db/schema_migrations/20180409170809
|
||||
db/schema_migrations/20180413022611
|
||||
db/schema_migrations/20180416155103
|
||||
db/schema_migrations/20180417090132
|
||||
db/schema_migrations/20180417101040
|
||||
db/schema_migrations/20180417101940
|
||||
db/schema_migrations/20180418053107
|
||||
db/schema_migrations/20180420010016
|
||||
db/schema_migrations/20180420010616
|
||||
db/schema_migrations/20180420080616
|
||||
db/schema_migrations/20180423204600
|
||||
db/schema_migrations/20180424090541
|
||||
db/schema_migrations/20180424134533
|
||||
db/schema_migrations/20180424151928
|
||||
db/schema_migrations/20180424160449
|
||||
db/schema_migrations/20180425075446
|
||||
db/schema_migrations/20180425131009
|
||||
db/schema_migrations/20180425205249
|
||||
db/schema_migrations/20180426102016
|
||||
db/schema_migrations/20180430101916
|
||||
db/schema_migrations/20180430143705
|
||||
db/schema_migrations/20180502122856
|
||||
db/schema_migrations/20180503131624
|
||||
db/schema_migrations/20180503141722
|
||||
db/schema_migrations/20180503150427
|
||||
db/schema_migrations/20180503175053
|
||||
db/schema_migrations/20180503175054
|
||||
db/schema_migrations/20180503193542
|
||||
db/schema_migrations/20180503193953
|
||||
db/schema_migrations/20180503200320
|
||||
db/schema_migrations/20180504195842
|
||||
db/schema_migrations/20180507083701
|
||||
db/schema_migrations/20180508055821
|
||||
db/schema_migrations/20180508100222
|
||||
db/schema_migrations/20180508102840
|
||||
db/schema_migrations/20180508135515
|
||||
db/schema_migrations/20180511090724
|
||||
db/schema_migrations/20180511131058
|
||||
db/schema_migrations/20180511174224
|
||||
db/schema_migrations/20180512061621
|
||||
db/schema_migrations/20180514161336
|
||||
db/schema_migrations/20180515005612
|
||||
db/schema_migrations/20180515121227
|
||||
db/schema_migrations/20180517082340
|
||||
db/schema_migrations/20180523042841
|
||||
db/schema_migrations/20180523125103
|
||||
db/schema_migrations/20180524132016
|
||||
db/schema_migrations/20180529093006
|
||||
db/schema_migrations/20180529152628
|
||||
db/schema_migrations/20180530135500
|
||||
db/schema_migrations/20180531185349
|
||||
db/schema_migrations/20180531220618
|
||||
db/schema_migrations/20180601213245
|
||||
db/schema_migrations/20180603190921
|
||||
db/schema_migrations/20180604123514
|
||||
db/schema_migrations/20180607071808
|
||||
db/schema_migrations/20180608091413
|
||||
db/schema_migrations/20180608110058
|
||||
db/schema_migrations/20180608201435
|
||||
db/schema_migrations/20180612103626
|
||||
db/schema_migrations/20180613081317
|
||||
db/schema_migrations/20180625113853
|
||||
db/schema_migrations/20180626125654
|
||||
db/schema_migrations/20180628124813
|
||||
db/schema_migrations/20180629153018
|
||||
db/schema_migrations/20180629191052
|
||||
db/schema_migrations/20180702120647
|
||||
db/schema_migrations/20180702124358
|
||||
db/schema_migrations/20180702134423
|
||||
db/schema_migrations/20180704145007
|
||||
db/schema_migrations/20180704204006
|
||||
db/schema_migrations/20180705160945
|
||||
db/schema_migrations/20180706223200
|
||||
db/schema_migrations/20180710162338
|
||||
db/schema_migrations/20180711103851
|
||||
db/schema_migrations/20180711103922
|
||||
db/schema_migrations/20180713092803
|
||||
db/schema_migrations/20180717125853
|
||||
db/schema_migrations/20180718005113
|
||||
db/schema_migrations/20180720023512
|
||||
db/schema_migrations/20180722103201
|
||||
db/schema_migrations/20180723135214
|
||||
db/schema_migrations/20180726172057
|
||||
db/schema_migrations/20180807153545
|
||||
db/schema_migrations/20180808162000
|
||||
db/schema_migrations/20180809195358
|
||||
db/schema_migrations/20180813101999
|
||||
db/schema_migrations/20180813102000
|
||||
db/schema_migrations/20180814153625
|
||||
db/schema_migrations/20180815040323
|
||||
db/schema_migrations/20180815160409
|
||||
db/schema_migrations/20180815170510
|
||||
db/schema_migrations/20180815175440
|
||||
db/schema_migrations/20180816161409
|
||||
db/schema_migrations/20180816193530
|
||||
db/schema_migrations/20180824202952
|
||||
db/schema_migrations/20180826111825
|
||||
db/schema_migrations/20180831164905
|
||||
db/schema_migrations/20180831164907
|
||||
db/schema_migrations/20180831164908
|
||||
db/schema_migrations/20180831164909
|
||||
db/schema_migrations/20180831164910
|
||||
db/schema_migrations/20180901171833
|
||||
db/schema_migrations/20180901200537
|
||||
db/schema_migrations/20180902070406
|
||||
db/schema_migrations/20180906101639
|
||||
db/schema_migrations/20180907015926
|
||||
db/schema_migrations/20180910115836
|
||||
db/schema_migrations/20180910153412
|
||||
db/schema_migrations/20180910153413
|
||||
db/schema_migrations/20180912111628
|
||||
db/schema_migrations/20180913142237
|
||||
db/schema_migrations/20180914162043
|
||||
db/schema_migrations/20180914201132
|
||||
db/schema_migrations/20180916011959
|
||||
db/schema_migrations/20180917172041
|
||||
db/schema_migrations/20180924141949
|
||||
db/schema_migrations/20180924190739
|
||||
db/schema_migrations/20180924201039
|
||||
db/schema_migrations/20180925200829
|
||||
db/schema_migrations/20180927073410
|
||||
db/schema_migrations/20181002172433
|
||||
db/schema_migrations/20181005110927
|
||||
db/schema_migrations/20181005125926
|
||||
db/schema_migrations/20181006004100
|
||||
db/schema_migrations/20181008145341
|
||||
db/schema_migrations/20181008145359
|
||||
db/schema_migrations/20181008200441
|
||||
db/schema_migrations/20181009190428
|
||||
db/schema_migrations/20181010133639
|
||||
db/schema_migrations/20181010235606
|
||||
db/schema_migrations/20181013005024
|
||||
db/schema_migrations/20181014203236
|
||||
db/schema_migrations/20181015155839
|
||||
db/schema_migrations/20181016141739
|
||||
db/schema_migrations/20181016152238
|
||||
db/schema_migrations/20181017001059
|
||||
db/schema_migrations/20181019032400
|
||||
db/schema_migrations/20181019032408
|
||||
db/schema_migrations/20181019105553
|
||||
db/schema_migrations/20181022135539
|
||||
db/schema_migrations/20181022173835
|
||||
db/schema_migrations/20181023104858
|
||||
db/schema_migrations/20181023144439
|
||||
db/schema_migrations/20181025115728
|
||||
db/schema_migrations/20181026091631
|
||||
db/schema_migrations/20181026143227
|
||||
db/schema_migrations/20181027114222
|
||||
db/schema_migrations/20181028120717
|
||||
db/schema_migrations/20181030135124
|
||||
db/schema_migrations/20181030154446
|
||||
db/schema_migrations/20181031145139
|
||||
db/schema_migrations/20181031190558
|
||||
db/schema_migrations/20181031190559
|
||||
db/schema_migrations/20181101091005
|
||||
db/schema_migrations/20181101091124
|
||||
db/schema_migrations/20181101144347
|
||||
db/schema_migrations/20181101191341
|
||||
db/schema_migrations/20181105201455
|
||||
db/schema_migrations/20181106135939
|
||||
db/schema_migrations/20181107054254
|
||||
db/schema_migrations/20181108091549
|
||||
db/schema_migrations/20181112103239
|
||||
db/schema_migrations/20181115140140
|
||||
db/schema_migrations/20181116050532
|
||||
db/schema_migrations/20181116141415
|
||||
db/schema_migrations/20181116141504
|
||||
db/schema_migrations/20181119081539
|
||||
db/schema_migrations/20181119132520
|
||||
db/schema_migrations/20181120082911
|
||||
db/schema_migrations/20181120091639
|
||||
db/schema_migrations/20181120151656
|
||||
db/schema_migrations/20181121101842
|
||||
db/schema_migrations/20181121101843
|
||||
db/schema_migrations/20181121111200
|
||||
db/schema_migrations/20181122160027
|
||||
db/schema_migrations/20181123042307
|
||||
db/schema_migrations/20181123135036
|
||||
db/schema_migrations/20181123144235
|
||||
db/schema_migrations/20181126150622
|
||||
db/schema_migrations/20181126153547
|
||||
db/schema_migrations/20181128123704
|
||||
db/schema_migrations/20181129104854
|
||||
db/schema_migrations/20181129104944
|
||||
db/schema_migrations/20181130102132
|
||||
db/schema_migrations/20181203002526
|
||||
db/schema_migrations/20181205171941
|
||||
db/schema_migrations/20181211092510
|
||||
db/schema_migrations/20181211092514
|
||||
db/schema_migrations/20181212104941
|
||||
db/schema_migrations/20181212171634
|
||||
db/schema_migrations/20181219130552
|
||||
db/schema_migrations/20181219145520
|
||||
db/schema_migrations/20181219145521
|
||||
# Removed in 71a3b0e470c64fccbb902390b1f856ee1547a978
|
||||
db/schema_migrations/20190225160300
|
||||
# Removed in 44f9d16edca328e5bb234b853f0d670ee0b30a26
|
||||
db/schema_migrations/20200615101135
|
||||
# Removed in cfae6ec2647
|
||||
db/schema_migrations/20180502134117
|
||||
db/schema_migrations/20180521162137
|
||||
db/schema_migrations/20180619121030
|
||||
db/schema_migrations/20180723130817
|
||||
db/schema_migrations/20180906051323
|
||||
db/schema_migrations/20180913051323
|
||||
db/schema_migrations/20180916014356
|
||||
db/schema_migrations/20181014121030
|
||||
db/schema_migrations/20181204154019
|
||||
db/schema_migrations/20180103234731
|
||||
db/schema_migrations/20180104001824
|
||||
db/schema_migrations/20180105233807
|
||||
db/schema_migrations/20180109150457
|
||||
db/schema_migrations/20180115013218
|
||||
db/schema_migrations/20180126165535
|
||||
db/schema_migrations/20180131104538
|
||||
db/schema_migrations/20180201101405
|
||||
db/schema_migrations/20180201192230
|
||||
db/schema_migrations/20180206184810
|
||||
db/schema_migrations/20180215143644
|
||||
db/schema_migrations/20180225180932
|
||||
db/schema_migrations/20180302230551
|
||||
db/schema_migrations/20180307164427
|
||||
db/schema_migrations/20180308234102
|
||||
db/schema_migrations/20180314174825
|
||||
db/schema_migrations/20180317020334
|
||||
db/schema_migrations/20180320142552
|
||||
db/schema_migrations/20180325034910
|
||||
db/schema_migrations/20180329230151
|
||||
db/schema_migrations/20180401213713
|
||||
db/schema_migrations/20180416112831
|
||||
db/schema_migrations/20180416205949
|
||||
db/schema_migrations/20180419031622
|
||||
db/schema_migrations/20180419171038
|
||||
db/schema_migrations/20180423165301
|
||||
db/schema_migrations/20180502124117
|
||||
db/schema_migrations/20180502125859
|
||||
db/schema_migrations/20180503154922
|
||||
db/schema_migrations/20180520211048
|
||||
db/schema_migrations/20180524115107
|
||||
db/schema_migrations/20180531031410
|
||||
db/schema_migrations/20180531221734
|
||||
db/schema_migrations/20180607154422
|
||||
db/schema_migrations/20180607154516
|
||||
db/schema_migrations/20180607154645
|
||||
db/schema_migrations/20180612175636
|
||||
db/schema_migrations/20180615152524
|
||||
db/schema_migrations/20180621100024
|
||||
db/schema_migrations/20180621100025
|
||||
db/schema_migrations/20180623053658
|
||||
db/schema_migrations/20180626171125
|
||||
db/schema_migrations/20180702114215
|
||||
db/schema_migrations/20180702181530
|
||||
db/schema_migrations/20180709153607
|
||||
db/schema_migrations/20180709183353
|
||||
db/schema_migrations/20180709184533
|
||||
db/schema_migrations/20180711014025
|
||||
db/schema_migrations/20180711014026
|
||||
db/schema_migrations/20180718100455
|
||||
db/schema_migrations/20180719161844
|
||||
db/schema_migrations/20180720082636
|
||||
db/schema_migrations/20180720120716
|
||||
db/schema_migrations/20180720120726
|
||||
db/schema_migrations/20180720121404
|
||||
db/schema_migrations/20180723023517
|
||||
db/schema_migrations/20180723081631
|
||||
db/schema_migrations/20180723134433
|
||||
db/schema_migrations/20180724161450
|
||||
db/schema_migrations/20180803001726
|
||||
db/schema_migrations/20180803041220
|
||||
db/schema_migrations/20180806145747
|
||||
db/schema_migrations/20180823132905
|
||||
db/schema_migrations/20180831134049
|
||||
db/schema_migrations/20180831152625
|
||||
db/schema_migrations/20180910104020
|
||||
db/schema_migrations/20180910105100
|
||||
db/schema_migrations/20180912113336
|
||||
db/schema_migrations/20180917145556
|
||||
db/schema_migrations/20180917171038
|
||||
db/schema_migrations/20180917171533
|
||||
db/schema_migrations/20180917171534
|
||||
db/schema_migrations/20180917171535
|
||||
db/schema_migrations/20180917213751
|
||||
db/schema_migrations/20180917214204
|
||||
db/schema_migrations/20180920043317
|
||||
db/schema_migrations/20180924070647
|
||||
db/schema_migrations/20180926101838
|
||||
db/schema_migrations/20180926140319
|
||||
db/schema_migrations/20180930171532
|
||||
db/schema_migrations/20181001172126
|
||||
db/schema_migrations/20181001172651
|
||||
db/schema_migrations/20181004131020
|
||||
db/schema_migrations/20181004131025
|
||||
db/schema_migrations/20181012151642
|
||||
db/schema_migrations/20181017131623
|
||||
db/schema_migrations/20181022131445
|
||||
db/schema_migrations/20181025000427
|
||||
db/schema_migrations/20181025030732
|
||||
db/schema_migrations/20181026085436
|
||||
db/schema_migrations/20181028092114
|
||||
db/schema_migrations/20181028092115
|
||||
db/schema_migrations/20181105122803
|
||||
db/schema_migrations/20181114163403
|
||||
db/schema_migrations/20181121174028
|
||||
db/schema_migrations/20181121175359
|
||||
db/schema_migrations/20181123090058
|
||||
db/schema_migrations/20181123100058
|
||||
db/schema_migrations/20181126125616
|
||||
db/schema_migrations/20181127130125
|
||||
db/schema_migrations/20181127133629
|
||||
db/schema_migrations/20181127203117
|
||||
db/schema_migrations/20181201151856
|
||||
db/schema_migrations/20181203154104
|
||||
db/schema_migrations/20181204031328
|
||||
db/schema_migrations/20181204031329
|
||||
db/schema_migrations/20181204031330
|
||||
db/schema_migrations/20181204031331
|
||||
db/schema_migrations/20181204135519
|
||||
db/schema_migrations/20181204135932
|
||||
db/schema_migrations/20181205093951
|
||||
db/schema_migrations/20181206121338
|
||||
db/schema_migrations/20181220163029
|
||||
db/schema_migrations/20181221135205
|
||||
db/schema_migrations/20181228140935
|
||||
db/schema_migrations/20190110200434
|
||||
db/schema_migrations/20190111183834
|
||||
db/schema_migrations/20190114040404
|
||||
db/schema_migrations/20190114040405
|
||||
db/schema_migrations/20190121140418
|
||||
db/schema_migrations/20190121140658
|
||||
db/schema_migrations/20190122101816
|
||||
db/schema_migrations/20190123211816
|
||||
db/schema_migrations/20190128104236
|
||||
db/schema_migrations/20190128172533
|
||||
db/schema_migrations/20190129013538
|
||||
db/schema_migrations/20190130164903
|
||||
db/schema_migrations/20190218031401
|
||||
db/schema_migrations/20190218144405
|
||||
db/schema_migrations/20190219134239
|
||||
db/schema_migrations/20190219210244
|
||||
db/schema_migrations/20190220112238
|
||||
db/schema_migrations/20190222105948
|
||||
db/schema_migrations/20190222110418
|
||||
db/schema_migrations/20190225173106
|
||||
db/schema_migrations/20190226154144
|
||||
db/schema_migrations/20190228134845
|
||||
db/schema_migrations/20190301095211
|
||||
db/schema_migrations/20190301182031
|
||||
db/schema_migrations/20190302144241
|
||||
db/schema_migrations/20190304020812
|
||||
db/schema_migrations/20190304223216
|
||||
db/schema_migrations/20190304223220
|
||||
db/schema_migrations/20190305162221
|
||||
db/schema_migrations/20190318020549
|
||||
db/schema_migrations/20190318021429
|
||||
db/schema_migrations/20190318120957
|
||||
db/schema_migrations/20190320162221
|
||||
db/schema_migrations/20190321103531
|
||||
db/schema_migrations/20190322145954
|
||||
db/schema_migrations/20190327085945
|
||||
db/schema_migrations/20190328210840
|
||||
db/schema_migrations/20190401150745
|
||||
db/schema_migrations/20190401150746
|
||||
db/schema_migrations/20190402112450
|
||||
db/schema_migrations/20180309215236
|
||||
db/schema_migrations/20180314172513
|
||||
db/schema_migrations/20180417102933
|
||||
db/schema_migrations/20180502130136
|
||||
db/schema_migrations/20180509091305
|
||||
db/schema_migrations/20180605213516
|
||||
db/schema_migrations/20180608150653
|
||||
db/schema_migrations/20180618193715
|
||||
db/schema_migrations/20180713171825
|
||||
db/schema_migrations/20180815043102
|
||||
db/schema_migrations/20180914195058
|
||||
db/schema_migrations/20181014131030
|
||||
db/schema_migrations/20181115140251
|
||||
db/schema_migrations/20181116100917
|
||||
db/schema_migrations/20181204040404
|
||||
db/schema_migrations/20181206121340
|
||||
db/schema_migrations/20181215161939
|
||||
db/schema_migrations/20181220165848
|
||||
db/schema_migrations/20190111231855
|
||||
# Removed in ef1efa0f650
|
||||
db/schema_migrations/20180406204716
|
||||
db/schema_migrations/20180521171529
|
||||
db/schema_migrations/20180831164904
|
||||
# Removed in 28ac2d30498
|
||||
db/schema_migrations/20180202111106
|
||||
# Removed in b87dcc238a8
|
||||
db/schema_migrations/20181218192239
|
||||
|
||||
# Removed in various revert commits
|
||||
db/schema_migrations/20180115094742
|
||||
db/schema_migrations/20180115113902
|
||||
db/schema_migrations/20190107151029
|
||||
db/schema_migrations/20190114184258
|
||||
db/schema_migrations/20190228092516
|
||||
db/schema_migrations/20190311132500
|
||||
db/schema_migrations/20190311132527
|
||||
db/schema_migrations/20190703001116
|
||||
db/schema_migrations/20190703001120
|
||||
db/schema_migrations/20190724091326
|
||||
db/schema_migrations/20190801072937
|
||||
db/schema_migrations/20191004134055
|
||||
db/schema_migrations/20191029060358
|
||||
db/schema_migrations/20191029061556
|
||||
db/schema_migrations/20191220102807
|
||||
db/schema_migrations/20200123092602
|
||||
db/schema_migrations/20200123101859
|
||||
db/schema_migrations/20200127111953
|
||||
db/schema_migrations/20200127131953
|
||||
db/schema_migrations/20200127141953
|
||||
db/schema_migrations/20200127151953
|
||||
db/schema_migrations/20200206111847
|
||||
db/schema_migrations/20200214173000
|
||||
db/schema_migrations/20200214174519
|
||||
db/schema_migrations/20200214174607
|
||||
db/schema_migrations/20200309105539
|
||||
db/schema_migrations/20200615203153
|
||||
|
|
|
@ -10,12 +10,13 @@ stages:
|
|||
- qa
|
||||
- post-qa
|
||||
- pages
|
||||
- notify
|
||||
|
||||
# always use `gitlab-org` runners, however
|
||||
# in cases where jobs require Docker-in-Docker, the job
|
||||
# definition must be extended with `.use-docker-in-docker`
|
||||
default:
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.27-lfs-2.9-chrome-83-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.28-lfs-2.9-chrome-84-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
tags:
|
||||
- gitlab-org
|
||||
# All jobs are interruptible by default
|
||||
|
@ -62,6 +63,27 @@ variables:
|
|||
ELASTIC_URL: "http://elastic:changeme@elasticsearch:9200"
|
||||
DOCKER_VERSION: "19.03.0"
|
||||
|
||||
# Preparing custom clone path to reduce space used by all random forks
|
||||
# on GitLab.com's Shared Runners. Our main forks - especially the security
|
||||
# ones - will have this variable overwritten in the project settings, so that
|
||||
# a security-related code or code using our protected variables will be never
|
||||
# stored on the same path as the community forks.
|
||||
# Part of the solution for the `no space left on device` problem described at
|
||||
# https://gitlab.com/gitlab-org/gitlab/issues/197876.
|
||||
#
|
||||
# For this purpose the https://gitlab.com/gitlab-org-forks group was created
|
||||
# to host a placeholder for the `/builds/gitlab-org-forks` path and ensure
|
||||
# that no legitimate project will ever use it and - by mistake - execute its
|
||||
# job on a shared working directory. It also requires proper configuration of
|
||||
# the Runner that executes the job (which was prepared for our shared runners
|
||||
# by https://ops.gitlab.net/gitlab-cookbooks/chef-repo/-/merge_requests/3977).
|
||||
#
|
||||
# Because of all of that PLEASE DO NOT CHANGE THE PATH.
|
||||
#
|
||||
# For more details and reasoning that brought this change please check
|
||||
# https://gitlab.com/gitlab-org/gitlab/-/merge_requests/24887
|
||||
GIT_CLONE_PATH: "/builds/gitlab-org-forks/${CI_PROJECT_NAME}"
|
||||
|
||||
include:
|
||||
- local: .gitlab/ci/build-images.gitlab-ci.yml
|
||||
- local: .gitlab/ci/cache-repo.gitlab-ci.yml
|
||||
|
@ -81,3 +103,4 @@ include:
|
|||
- local: .gitlab/ci/test-metadata.gitlab-ci.yml
|
||||
- local: .gitlab/ci/yaml.gitlab-ci.yml
|
||||
- local: .gitlab/ci/releases.gitlab-ci.yml
|
||||
- local: .gitlab/ci/notify.gitlab-ci.yml
|
||||
|
|
|
@ -2,13 +2,12 @@
|
|||
# project here: https://gitlab.com/gitlab-org/gitlab/-/project_members
|
||||
# As described in https://docs.gitlab.com/ee/user/project/code_owners.html
|
||||
|
||||
# Backend Maintainers are the default for all ruby files
|
||||
[Backend]
|
||||
*.rb @gitlab-org/maintainers/rails-backend
|
||||
*.rake @gitlab-org/maintainers/rails-backend
|
||||
|
||||
# Technical writing team are the default reviewers for all markdown docs
|
||||
[Documentation]
|
||||
/doc/ @gl-docsteam
|
||||
# Doc subpaths
|
||||
/doc/administration/monitoring/ @aqualls
|
||||
/doc/development/ @marcia @mjang1
|
||||
/doc/development/documentation/ @mikelewis
|
||||
|
@ -19,7 +18,127 @@
|
|||
/doc/user/project/clusters @aqualls
|
||||
/doc/.vale/ @marcel.amirault @eread @aqualls @mikelewis
|
||||
|
||||
# Frontend maintainers should see everything in `app/assets/`
|
||||
[Docs Create]
|
||||
/doc/user/project/merge_requests/allow_collaboration.md @marcia
|
||||
/doc/user/project/merge_requests/authorization_for_merge_requests.md @marcia
|
||||
/doc/user/project/merge_requests/cherry_pick_changes.md @marcia
|
||||
/doc/user/project/merge_requests/creating_merge_requests.md @marcia
|
||||
/doc/user/project/merge_requests/fast_forward_merge.md @marcia
|
||||
/doc/user/project/merge_requests/getting_started.md @marcia
|
||||
/doc/user/project/merge_requests/index.md @marcia
|
||||
/doc/user/project/merge_requests/merge_request_approvals.md @marcia
|
||||
/doc/user/project/merge_requests/merge_request_dependencies.md @marcia
|
||||
/doc/user/project/merge_requests/resolve_conflicts.md @marcia
|
||||
/doc/user/project/merge_requests/revert_changes.md @marcia
|
||||
/doc/user/project/merge_requests/reviewing_and_managing_merge_requests.md @marcia
|
||||
/doc/user/project/merge_requests/squash_and_merge.md @marcia
|
||||
/doc/user/project/merge_requests/work_in_progress_merge_requests.md @marcia
|
||||
/doc/user/project/repository/file_finder.md @marcia
|
||||
/doc/user/project/repository/forking_workflow.md @marcia
|
||||
/doc/user/project/repository/git_blame.md @marcia
|
||||
/doc/user/project/repository/git_history.md @marcia
|
||||
/doc/user/project/repository/index.md @marcia
|
||||
/doc/user/project/repository/repository_mirroring.md @marcia
|
||||
/doc/user/project/repository/web_editor.md @marcia
|
||||
/doc/user/project/autocomplete_characters.md @marcia
|
||||
/doc/user/project/badges.md @marcia
|
||||
/doc/user/project/code_intelligence.md @marcia
|
||||
/doc/user/project/code_owners.md @marcia
|
||||
/doc/user/project/file_lock.md @marcia
|
||||
/doc/user/project/git_attributes.md @marcia
|
||||
/doc/user/project/highlighting.md @marcia
|
||||
/doc/user/project/index.md @marcia
|
||||
/doc/user/project/protected_branches.md @marcia
|
||||
/doc/user/project/protected_tags.md @marcia
|
||||
/doc/user/project/push_options.md @marcia
|
||||
/doc/user/project/repository/branches/index.md @marcia
|
||||
/doc/user/project/repository/gpg_signed_commits/index.md @marcia
|
||||
/doc/user/project/repository/jupyter_notebooks/index.md @marcia
|
||||
/doc/user/project/repository/x509_signed_commits/index.md @marcia
|
||||
/doc/user/project/settings/import_export.md @marcia
|
||||
/doc/user/project/settings/index.md @marcia
|
||||
/doc/user/project/settings/project_access_tokens.md @marcia
|
||||
/doc/user/project/static_site_editor/index.md @marcia
|
||||
/doc/user/project/web_ide/index.md @marcia
|
||||
/doc/user/project/wiki/index.md @marcia
|
||||
/doc/gitlab-basics/README.md @marcia
|
||||
/doc/gitlab-basics/add-file.md @marcia
|
||||
/doc/gitlab-basics/command-line-commands.md @marcia
|
||||
/doc/gitlab-basics/create-branch.md @marcia
|
||||
/doc/gitlab-basics/create-project.md @marcia
|
||||
/doc/gitlab-basics/create-your-ssh-keys.md @marcia
|
||||
/doc/gitlab-basics/feature_branch_workflow.md @marcia
|
||||
/doc/gitlab-basics/fork-project.md @marcia
|
||||
/doc/gitlab-basics/start-using-git.md @marcia
|
||||
/doc/integration/sourcegraph.md @marcia
|
||||
/doc/intro/README.md @marcia
|
||||
/doc/push_rules/push_rules.md @marcia
|
||||
/doc/ssh/README.md @marcia
|
||||
/doc/topics/git/feature_branch_development.md @marcia
|
||||
/doc/topics/git/how_to_install_git/index.md @marcia
|
||||
/doc/topics/git/index.md @marcia
|
||||
/doc/topics/git/lfs/index.md @marcia
|
||||
/doc/topics/git/lfs/migrate_from_git_annex_to_git_lfs.md @marcia
|
||||
/doc/topics/git/numerous_undo_possibilities_in_git/index.md @marcia
|
||||
/doc/topics/git/partial_clone.md @marcia
|
||||
/doc/topics/git/troubleshooting_git.md @marcia
|
||||
/doc/topics/git/useful_git_commands.md @marcia
|
||||
/doc/topics/gitlab_flow.md @marcia
|
||||
/doc/user/index.md @marcia
|
||||
/doc/user/snippets.md @marcia
|
||||
/doc/administration/issue_closing_pattern.md @marcia
|
||||
/doc/user/asciidoc.md @marcia
|
||||
/doc/user/markdown.md @marcia
|
||||
/doc/user/search/advanced_global_search.md @marcia
|
||||
/doc/user/search/advanced_search_syntax.md @marcia
|
||||
/doc/user/search/index.md @marcia
|
||||
/doc/administration/file_hooks.md @marcia
|
||||
/doc/administration/git_annex.md @marcia
|
||||
/doc/administration/git_protocol.md @marcia
|
||||
/doc/administration/integration/plantuml.md @marcia
|
||||
/doc/administration/invalidate_markdown_cache.md @marcia
|
||||
/doc/administration/issue_closing_pattern.md @marcia
|
||||
/doc/administration/lfs/index.md @marcia
|
||||
/doc/administration/merge_request_diffs.md @marcia
|
||||
/doc/administration/repository_checks.md @marcia
|
||||
/doc/administration/snippets/index.md @marcia
|
||||
/doc/administration/static_objects_external_storage.md @marcia
|
||||
/doc/api/access_requests.md @marcia
|
||||
/doc/api/branches.md @marcia
|
||||
/doc/api/commits.md @marcia
|
||||
/doc/api/discussions.md @marcia
|
||||
/doc/api/group_wikis.md @marcia
|
||||
/doc/api/keys.md @marcia
|
||||
/doc/api/markdown.md @marcia
|
||||
/doc/api/merge_request_approvals.md @marcia
|
||||
/doc/api/merge_request_context_commits.md @marcia
|
||||
/doc/api/merge_requests.md @marcia
|
||||
/doc/api/project_aliases.md @marcia
|
||||
/doc/api/project_badges.md @marcia
|
||||
/doc/api/project_import_export.md @marcia
|
||||
/doc/api/project_level_variables.md @marcia
|
||||
/doc/api/project_snippets.md @marcia
|
||||
/doc/api/project_statistics.md @marcia
|
||||
/doc/api/project_templates.md @marcia
|
||||
/doc/api/project_vulnerabilities.md @marcia
|
||||
/doc/api/protected_branches.md @marcia
|
||||
/doc/api/protected_tags.md @marcia
|
||||
/doc/api/remote_mirrors.md @marcia
|
||||
/doc/api/repositories.md @marcia
|
||||
/doc/api/repository_files.md @marcia
|
||||
/doc/api/repository_submodules.md @marcia
|
||||
/doc/api/search.md @marcia
|
||||
/doc/api/snippets.md @marcia
|
||||
/doc/api/suggestions.md @marcia
|
||||
/doc/api/tags.md @marcia
|
||||
/doc/api/visual_review_discussions.md @marcia
|
||||
/doc/api/wikis.md @marcia
|
||||
/doc/user/admin_area/settings/account_and_limit_settings.md @marcia
|
||||
/doc/user/admin_area/settings/instance_template_repository.md @marcia
|
||||
/doc/user/admin_area/settings/push_event_activities_limit.md @marcia
|
||||
/doc/user/admin_area/settings/visibility_and_access_controls.md @marcia
|
||||
|
||||
[Frontend]
|
||||
*.scss @annabeldunstone @gitlab-org/maintainers/frontend
|
||||
*.js @gitlab-org/maintainers/frontend
|
||||
/app/assets/ @gitlab-org/maintainers/frontend
|
||||
|
@ -29,7 +148,7 @@
|
|||
/spec/frontend/ @gitlab-org/maintainers/frontend
|
||||
/ee/spec/frontend/ @gitlab-org/maintainers/frontend
|
||||
|
||||
# Database maintainers should review changes in `db/`
|
||||
[Database]
|
||||
/db/ @gitlab-org/maintainers/database
|
||||
/ee/db/ @gitlab-org/maintainers/database
|
||||
/lib/gitlab/background_migration/ @gitlab-org/maintainers/database
|
||||
|
@ -41,19 +160,7 @@
|
|||
/app/finders/ @gitlab-org/maintainers/database
|
||||
/ee/app/finders/ @gitlab-org/maintainers/database
|
||||
|
||||
# Feature specific owners
|
||||
/ee/lib/ee/gitlab/auth/ldap/ @dblessing @mkozono
|
||||
/lib/gitlab/auth/ldap/ @dblessing @mkozono
|
||||
/lib/gitlab/ci/templates/ @nolith @dosuken123
|
||||
/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml @DylanGriffith @mayra-cabrera @tkuah
|
||||
/lib/gitlab/ci/templates/Security/ @plafoucriere @gonzoyumo @twoodham @sethgitlab
|
||||
/ee/app/models/project_alias.rb @patrickbajao
|
||||
/ee/lib/api/project_aliases.rb @patrickbajao
|
||||
|
||||
# Quality owned files
|
||||
/qa/ @gl-quality
|
||||
|
||||
# Engineering Productivity owned files
|
||||
[Engineering Productivity]
|
||||
/.gitlab-ci.yml @gl-quality/eng-prod
|
||||
/.gitlab/ci/ @gl-quality/eng-prod
|
||||
/.gitlab/ci/docs.gitlab-ci.yml @gl-quality/eng-prod @gl-docsteam
|
||||
|
@ -66,16 +173,45 @@ Dangerfile @gl-quality/eng-prod
|
|||
/scripts/frontend/ @gl-quality/eng-prod @gitlab-org/maintainers/frontend
|
||||
.editorconfig @gl-quality/eng-prod
|
||||
|
||||
# Telemetry owner files
|
||||
/ee/lib/gitlab/usage_data_counters/ @gitlab-org/growth/telemetry
|
||||
/ee/lib/ee/gitlab/usage_data.rb @gitlab-org/growth/telemetry
|
||||
/lib/gitlab/grafana_embed_usage_data.rb @gitlab-org/growth/telemetry
|
||||
/lib/gitlab/usage_data.rb @gitlab-org/growth/telemetry
|
||||
/lib/gitlab/cycle_analytics/usage_data.rb @gitlab-org/growth/telemetry
|
||||
/lib/gitlab/usage_data_counters/ @gitlab-org/growth/telemetry
|
||||
[End-to-end]
|
||||
/qa/ @gl-quality
|
||||
|
||||
[LDAP]
|
||||
/ee/lib/ee/gitlab/auth/ldap/ @dblessing @mkozono
|
||||
/lib/gitlab/auth/ldap/ @dblessing @mkozono
|
||||
|
||||
[Templates]
|
||||
/lib/gitlab/ci/templates/ @nolith @dosuken123
|
||||
/lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml @DylanGriffith @mayra-cabrera @tkuah
|
||||
/lib/gitlab/ci/templates/Security/ @plafoucriere @gonzoyumo @twoodham @sethgitlab
|
||||
|
||||
[Project Alias]
|
||||
/ee/app/models/project_alias.rb @patrickbajao
|
||||
/ee/lib/api/project_aliases.rb @patrickbajao
|
||||
|
||||
# Secure & Threat Management ownership delineation
|
||||
# https://about.gitlab.com/handbook/engineering/development/threat-management/delineate-secure-threat-management.html#technical-boundaries
|
||||
[Secure]
|
||||
/ee/app/models/vulnerability.rb @gitlab-org/secure/threat-insights-backend-team
|
||||
/ee/app/models/security/ @gitlab-org/secure/threat-insights-backend-team
|
||||
/ee/app/models/vulnerabilities/ @gitlab-org/secure/threat-insights-backend-team
|
||||
/ee/lib/gitlab/ci/parsers/license_compliance/ @gitlab-org/secure/composition-analysis-be
|
||||
/ee/lib/gitlab/ci/parsers/security/ @gitlab-org/secure/composition-analysis-be @gitlab-org/secure/dynamic-analysis-be @gitlab-org/secure/static-analysis-be @gitlab-org/secure/fuzzing-be
|
||||
/ee/lib/gitlab/ci/reports/coverage_fuzzing/ @gitlab-org/secure/fuzzing-be
|
||||
/ee/lib/gitlab/ci/reports/dependency_list/ @gitlab-org/secure/composition-analysis-be
|
||||
/ee/lib/gitlab/ci/reports/license_scanning/ @gitlab-org/secure/composition-analysis-be
|
||||
/ee/lib/gitlab/ci/reports/security/ @gitlab-org/secure/composition-analysis-be @gitlab-org/secure/dynamic-analysis-be @gitlab-org/secure/static-analysis-be @gitlab-org/secure/fuzzing-be
|
||||
|
||||
[Code Owners]
|
||||
/ee/lib/gitlab/code_owners.rb @reprazent @kerrizor @garyh
|
||||
/ee/lib/gitlab/code_owners/ @reprazent @kerrizor @garyh
|
||||
/ee/spec/lib/gitlab/code_owners/ @reprazent @kerrizor @garyh
|
||||
/doc/user/project/code_owners.md @reprazent @kerrizor @garyh
|
||||
|
||||
[Telemetry]
|
||||
/ee/lib/gitlab/usage_data_counters/ @gitlab-org/growth/telemetry/engineers
|
||||
/ee/lib/ee/gitlab/usage_data.rb @gitlab-org/growth/telemetry/engineers
|
||||
/lib/gitlab/grafana_embed_usage_data.rb @gitlab-org/growth/telemetry/engineers
|
||||
/lib/gitlab/usage_data.rb @gitlab-org/growth/telemetry/engineers
|
||||
/lib/gitlab/cycle_analytics/usage_data.rb @gitlab-org/growth/telemetry/engineers
|
||||
/lib/gitlab/usage_data_counters/ @gitlab-org/growth/telemetry/engineers
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
review-docs-deploy:
|
||||
extends: .review-docs
|
||||
script:
|
||||
- ./scripts/trigger-build-docs deploy
|
||||
- ./scripts/trigger-build docs deploy
|
||||
|
||||
# Cleanup remote environment of gitlab-docs
|
||||
review-docs-cleanup:
|
||||
|
@ -36,7 +36,7 @@ review-docs-cleanup:
|
|||
name: review-docs/$DOCS_GITLAB_REPO_SUFFIX-$CI_MERGE_REQUEST_IID
|
||||
action: stop
|
||||
script:
|
||||
- ./scripts/trigger-build-docs cleanup
|
||||
- ./scripts/trigger-build docs cleanup
|
||||
|
||||
docs lint:
|
||||
extends:
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
extends:
|
||||
- .frontend-base
|
||||
- .assets-compile-cache
|
||||
image: registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-git-2.27-lfs-2.9-node-12.x-yarn-1.21-graphicsmagick-1.3.34
|
||||
image: registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-git-2.28-lfs-2.9-node-12.x-yarn-1.21-graphicsmagick-1.3.34
|
||||
variables:
|
||||
WEBPACK_VENDOR_DLL: "true"
|
||||
stage: prepare
|
||||
|
|
|
@ -64,39 +64,39 @@
|
|||
policy: pull
|
||||
|
||||
.use-pg11:
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.27-lfs-2.9-chrome-83-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.28-lfs-2.9-chrome-84-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
services:
|
||||
- name: postgres:11.6
|
||||
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
|
||||
- name: redis:alpine
|
||||
- name: redis:4.0-alpine
|
||||
variables:
|
||||
POSTGRES_HOST_AUTH_METHOD: trust
|
||||
|
||||
.use-pg12:
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.27-lfs-2.9-chrome-83-node-12.x-yarn-1.21-postgresql-12-graphicsmagick-1.3.34"
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.28-lfs-2.9-chrome-84-node-12.x-yarn-1.21-postgresql-12-graphicsmagick-1.3.34"
|
||||
services:
|
||||
- name: postgres:12
|
||||
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
|
||||
- name: redis:alpine
|
||||
- name: redis:4.0-alpine
|
||||
variables:
|
||||
POSTGRES_HOST_AUTH_METHOD: trust
|
||||
|
||||
.use-pg11-ee:
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.27-lfs-2.9-chrome-83-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.28-lfs-2.9-chrome-84-node-12.x-yarn-1.21-postgresql-11-graphicsmagick-1.3.34"
|
||||
services:
|
||||
- name: postgres:11.6
|
||||
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
|
||||
- name: redis:alpine
|
||||
- name: redis:4.0-alpine
|
||||
- name: elasticsearch:6.4.2
|
||||
variables:
|
||||
POSTGRES_HOST_AUTH_METHOD: trust
|
||||
|
||||
.use-pg12-ee:
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.27-lfs-2.9-chrome-83-node-12.x-yarn-1.21-postgresql-12-graphicsmagick-1.3.34"
|
||||
image: "registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.6-golang-1.14-git-2.28-lfs-2.9-chrome-84-node-12.x-yarn-1.21-postgresql-12-graphicsmagick-1.3.34"
|
||||
services:
|
||||
- name: postgres:12
|
||||
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
|
||||
- name: redis:alpine
|
||||
- name: redis:4.0-alpine
|
||||
- name: elasticsearch:6.4.2
|
||||
variables:
|
||||
POSTGRES_HOST_AUTH_METHOD: trust
|
||||
|
|
23
.gitlab/ci/notify.gitlab-ci.yml
Normal file
23
.gitlab/ci/notify.gitlab-ci.yml
Normal file
|
@ -0,0 +1,23 @@
|
|||
.notify-slack:
|
||||
image: alpine
|
||||
stage: notify
|
||||
dependencies: []
|
||||
cache: {}
|
||||
before_script:
|
||||
- apk update && apk add git curl bash
|
||||
|
||||
notify-update-gitaly:
|
||||
extends:
|
||||
- .notify-slack
|
||||
rules:
|
||||
- if: '$CI_MERGE_REQUEST_IID && $CI_COMMIT_BRANCH == $GITALY_UPDATE_BRANCH'
|
||||
when: on_failure
|
||||
allow_failure: true
|
||||
variables:
|
||||
NOTIFY_CHANNEL: g_create_gitaly
|
||||
GITALY_UPDATE_BRANCH: release-tools/update-gitaly
|
||||
MERGE_REQUEST_URL: ${CI_MERGE_REQUEST_PROJECT_URL}/-/merge_requests/${CI_MERGE_REQUEST_IID}
|
||||
script:
|
||||
- echo "NOTIFY_CHANNEL is ${NOTIFY_CHANNEL}"
|
||||
- echo "CI_PIPELINE_URL is ${CI_PIPELINE_URL}"
|
||||
- scripts/slack ${NOTIFY_CHANNEL} "☠️ \`${GITALY_UPDATE_BRANCH}\` failed! ☠️ See ${CI_PIPELINE_URL} (triggered from ${MERGE_REQUEST_URL})" ci_failing
|
|
@ -59,6 +59,10 @@ package-and-qa:
|
|||
extends:
|
||||
- .package-and-qa-base
|
||||
- .qa:rules:package-and-qa
|
||||
# This job often times out, so temporarily use private runners and a long timeout: https://gitlab.com/gitlab-org/gitlab/-/issues/238563
|
||||
tags:
|
||||
- prm
|
||||
timeout: 4h
|
||||
needs:
|
||||
- job: build-qa-image
|
||||
artifacts: false
|
||||
|
|
|
@ -70,7 +70,6 @@
|
|||
- run_timed_command "scripts/gitaly-test-build"
|
||||
- run_timed_command "scripts/gitaly-test-spawn"
|
||||
- source scripts/rspec_helpers.sh
|
||||
- scripts/prepare_postgres_fdw.sh
|
||||
- rspec_paralellized_job "--tag ~quarantine --tag geo"
|
||||
|
||||
.rspec-ee-base-geo-pg11:
|
||||
|
|
|
@ -15,7 +15,7 @@ code_quality:
|
|||
stage: test
|
||||
needs: []
|
||||
variables:
|
||||
CODE_QUALITY_IMAGE: "registry.gitlab.com/gitlab-org/ci-cd/codequality:0.85.10"
|
||||
CODE_QUALITY_IMAGE: "registry.gitlab.com/gitlab-org/ci-cd/codequality:0.85.10-gitlab.1"
|
||||
script:
|
||||
- |
|
||||
if ! docker info &>/dev/null; then
|
||||
|
@ -58,7 +58,7 @@ code_quality:
|
|||
SAST_ANALYZER_IMAGE_PREFIX: "registry.gitlab.com/gitlab-org/security-products/analyzers"
|
||||
SAST_ANALYZER_IMAGE_TAG: 2
|
||||
SAST_BRAKEMAN_LEVEL: 2 # GitLab-specific
|
||||
SAST_EXCLUDED_PATHS: qa,spec,doc,ee/spec # GitLab-specific
|
||||
SAST_EXCLUDED_PATHS: qa,spec,doc,ee/spec,config/gitlab.yml.example # GitLab-specific
|
||||
SAST_DISABLE_BABEL: "true"
|
||||
script:
|
||||
- /analyzer run
|
||||
|
@ -150,7 +150,7 @@ dependency_scanning:
|
|||
## We need to duplicate this job's definition because it seems it's impossible to
|
||||
## override an included `only.refs`.
|
||||
## See https://gitlab.com/gitlab-org/gitlab/issues/31371.
|
||||
#dast:
|
||||
# dast:
|
||||
# extends:
|
||||
# - .default-retry
|
||||
# - .reports:rules:dast
|
||||
|
|
|
@ -125,6 +125,7 @@
|
|||
.db-patterns: &db-patterns
|
||||
- "{,ee/}{,spec/}{db,migrations}/**/*"
|
||||
- "{,ee/}{,spec/}lib/{,ee/}gitlab/background_migration/**/*"
|
||||
- "config/prometheus/common_metrics.yml" # Used by Gitlab::DatabaseImporters::CommonMetrics::Importer
|
||||
|
||||
.backstage-patterns: &backstage-patterns
|
||||
- "Dangerfile"
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
<!-- NOTE: Please add a DevOps stage label (format `devops:<stage_name>`)
|
||||
and assign the technical writer who is
|
||||
[listed for that stage](https://about.gitlab.com/handbook/product/categories/#devops-stages). -->
|
||||
[listed for that stage](https://about.gitlab.com/handbook/product/product-categories/#devops-stages). -->
|
||||
|
||||
|
||||
## References
|
||||
|
|
|
@ -24,7 +24,7 @@
|
|||
* Any concepts, procedures, reference info we could add to make it easier to successfully use GitLab?
|
||||
* Include use cases, benefits, and/or goals for this work.
|
||||
* If adding content: What audience is it intended for? (What roles and scenarios?)
|
||||
For ideas, see personas at https://design.gitlab.com/research/personas or the persona labels at
|
||||
For ideas, see personas at https://about.gitlab.com/handbook/marketing/product-marketing/roles-personas/ or the persona labels at
|
||||
https://gitlab.com/groups/gitlab-org/-/labels?utf8=%E2%9C%93&subscribed=&search=persona%3A
|
||||
-->
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@ Remove the `:feature_name` feature flag ...
|
|||
|
||||
## Expectations
|
||||
|
||||
### What are we expecting to happen?
|
||||
### What are we expecting to happen?
|
||||
|
||||
### What might happen if this goes wrong?
|
||||
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
<!-- The first four sections: "Problem to solve", "Intended users", "User experience goal", and "Proposal", are strongly recommended, while the rest of the sections can be filled out during the problem validation or breakdown phase. However, keep in mind that providing complete and relevant information early helps our product team validate the problem and start working on a solution. -->
|
||||
<!-- The first four sections: "Problem to solve", "Intended users", "User experience goal", and "Proposal", are strongly recommended, while the rest of the sections can be filled out during the problem validation or breakdown phase. However, keep in mind that providing complete and relevant information early helps our product team validate the problem and start working on a solution. -->
|
||||
|
||||
### Problem to solve
|
||||
|
||||
<!-- What problem do we solve? Try to define the who/what/why of the opportunity as a user story. For example, "As a (who), I want (what), so I can (why/value)." -->
|
||||
<!-- What problem do we solve? Try to define the who/what/why of the opportunity as a user story. For example, "As a (who), I want (what), so I can (why/value)." -->
|
||||
|
||||
### Intended users
|
||||
|
||||
|
@ -78,7 +78,7 @@ See the test engineering planning process and reach out to your counterpart Soft
|
|||
|
||||
### What is the type of buyer?
|
||||
|
||||
<!-- What is the buyer persona for this feature? See https://about.gitlab.com/handbook/marketing/product-marketing/roles-personas/buyer-persona/
|
||||
<!-- What is the buyer persona for this feature? See https://about.gitlab.com/handbook/marketing/product-marketing/roles-personas/buyer-persona/
|
||||
In which enterprise tier should this feature go? See https://about.gitlab.com/handbook/product/pricing/#four-tiers -->
|
||||
|
||||
### Is this a cross-stage feature?
|
||||
|
@ -87,4 +87,7 @@ In which enterprise tier should this feature go? See https://about.gitlab.com/ha
|
|||
|
||||
### Links / references
|
||||
|
||||
<!-- Label reminders - you should have one of each of the following labels if you can figure out the correct ones -->
|
||||
/label ~devops:: ~group: ~Category:
|
||||
|
||||
/label ~feature
|
||||
|
|
|
@ -68,10 +68,10 @@ a nightly pipeline, select ~"found:nightly".
|
|||
|
||||
<!--
|
||||
https://about.gitlab.com/handbook/engineering/quality/guidelines/#priorities:
|
||||
- ~P1: Tests that are needed to verify fundamental GitLab functionality.
|
||||
- ~P2: Tests that deal with external integrations which may take a longer time to debug and fix.
|
||||
- ~P::1: Tests that are needed to verify fundamental GitLab functionality.
|
||||
- ~P::2: Tests that deal with external integrations which may take a longer time to debug and fix.
|
||||
-->
|
||||
/label ~P
|
||||
/label ~P::
|
||||
|
||||
<!-- Select the current milestone if ~P1 or the next milestone if ~P2. -->
|
||||
<!-- Select the current milestone if ~P::1 or the next milestone if ~P::2. -->
|
||||
/milestone %
|
||||
|
|
|
@ -38,4 +38,12 @@ If you are aware of tests that need to be written or adjusted apart from unit te
|
|||
please list them here.
|
||||
-->
|
||||
|
||||
/label ~backstage
|
||||
<!--
|
||||
Please select the appropriate label from the following:
|
||||
~"feature::addition"
|
||||
~"feature::maintenance"
|
||||
~"tooling::pipelines"
|
||||
~"tooling::workflow"
|
||||
-->
|
||||
|
||||
/label ~"feature::maintenance"
|
||||
|
|
|
@ -8,12 +8,6 @@ Set the title to: `Security Release: 12.2.X, 12.1.X, and 12.0.X`
|
|||
|
||||
-------
|
||||
|
||||
## Releases tasks
|
||||
|
||||
- https://gitlab.com/gitlab-org/release/docs/blob/master/general/security/release-manager.md
|
||||
- https://gitlab.com/gitlab-org/release/docs/blob/master/general/security/developer.md
|
||||
- https://gitlab.com/gitlab-org/release/docs/blob/master/general/security/security-engineer.md
|
||||
|
||||
## Version issues:
|
||||
|
||||
12.2.X, 12.1.X, 12.0.X: {release task link}
|
||||
|
@ -25,11 +19,15 @@ your security issues as related to this release tracking issue. You can do this
|
|||
in the "Linked issues" section below this issue description.
|
||||
|
||||
:warning: If your security issues are not marked as related to this release
|
||||
tracking issue, their merge requests may not be included in the security
|
||||
tracking issue, their merge requests will not be included in the security
|
||||
release.
|
||||
|
||||
## QA
|
||||
{QA issue link}
|
||||
### Branches to target in GitLab Security
|
||||
|
||||
Your Security Implementation Issue should have `4` merge requests associated:
|
||||
|
||||
- [master and 3 backports](https://gitlab.com/gitlab-org/release/docs/-/blob/master/general/security/developer.md#backports)
|
||||
- Backports should target the stable branches for the versions mentioned included in this Security Release
|
||||
|
||||
## Blog post
|
||||
|
|
@ -28,8 +28,8 @@ After your merge request has been approved according to our [approval guidelines
|
|||
* You can use the script `bin/secpick` instead of the following steps, to help you cherry-picking. See the [secpick documentation]
|
||||
- [ ] Create each MR targeting the stable branch `X-Y-stable`, using the [Security Release merge request template].
|
||||
* Every merge request will have its own set of TODOs, so make sure to complete those.
|
||||
- [ ] On the "Related merge requests" section, ensure all MRs are linked to this issue.
|
||||
* This section should only list the merge requests created for this issue: One targeting `master` and the 3 backports.
|
||||
- [ ] On the "Related merge requests" section, ensure that `4` merge requests are associated: The one targeting `master` and the `3` backports.
|
||||
- [ ] If this issue requires less than `4` merge requests, post a message on the Security Release Tracking Issue and ping the Release Managers.
|
||||
|
||||
## Documentation and final details
|
||||
|
||||
|
@ -62,7 +62,6 @@ After your merge request has been approved according to our [approval guidelines
|
|||
[security process for developers]: https://gitlab.com/gitlab-org/release/docs/blob/master/general/security/developer.md
|
||||
[secpick documentation]: https://gitlab.com/gitlab-org/release/docs/-/blob/master/general/security/utilities/secpick_script.md
|
||||
[security Release merge request template]: https://gitlab.com/gitlab-org/security/gitlab/blob/master/.gitlab/merge_request_templates/Security%20Release.md
|
||||
[code review process]: https://docs.gitlab.com/ee/development/code_review.html
|
||||
[approval guidelines]: https://docs.gitlab.com/ee/development/code_review.html#approval-guidelines
|
||||
[issue as related]: https://docs.gitlab.com/ee/user/project/issues/related_issues.html#adding-a-related-issue
|
||||
|
||||
|
|
31
.gitlab/issue_templates/actionable_insight.md
Normal file
31
.gitlab/issue_templates/actionable_insight.md
Normal file
|
@ -0,0 +1,31 @@
|
|||
## Actionable Insights
|
||||
Actionable insights always have a follow-up action that needs to take place as a result of the research observation or data, and a clear recommendation or action associated with it. An actionable insight both defines the insight and clearly calls out the next step. These insights are tracked over time.
|
||||
|
||||
#### Link
|
||||
|
||||
- [ ] Provide the link to the Dovetail actionable insight you created earlier (this should contain all the essential details)
|
||||
- [ ] If applicable, link this actionable insight issue back to the original Research Issue in the GitLab UX Research project
|
||||
|
||||
#### Assign
|
||||
|
||||
- [ ] Assign this issue to the appropriate Product Manager, Product Designer, or UX Researcher
|
||||
|
||||
#### Description
|
||||
|
||||
- [ ] Provide some brief detials on the actionable insight and the action to take
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
|
||||
| | PLEASE COMPLETE THE BELOW |
|
||||
| ------ | ------ |
|
||||
| Dovetail link: | (URL goes here) |
|
||||
| Details: | (details go here) |
|
||||
| Action to take: | (action goes here) |
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
~"Actionable Insight"
|
|
@ -113,7 +113,6 @@ linters:
|
|||
- "app/views/help/instance_configuration.html.haml"
|
||||
- "app/views/help/instance_configuration/_gitlab_ci.html.haml"
|
||||
- "app/views/help/instance_configuration/_gitlab_pages.html.haml"
|
||||
- "app/views/help/ui.html.haml"
|
||||
- "app/views/import/bitbucket/status.html.haml"
|
||||
- "app/views/import/bitbucket_server/status.html.haml"
|
||||
- "app/views/invites/show.html.haml"
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
"ul-style": {
|
||||
"style": "dash"
|
||||
},
|
||||
"no-trailing-spaces": false,
|
||||
"line-length": false,
|
||||
"no-duplicate-header": {
|
||||
"allow_different_nesting": true
|
||||
|
|
|
@ -44,6 +44,22 @@ PreCommit:
|
|||
# on_warn: fail # Treat all warnings as failures
|
||||
ScssLint:
|
||||
enabled: true
|
||||
MarkdownLint:
|
||||
enabled: true
|
||||
description: 'Lint documentation for Markdown errors'
|
||||
required_executable: 'node_modules/.bin/markdownlint'
|
||||
flags: ['--config', '.markdownlint.json', 'doc/**/*.md']
|
||||
install_command: 'yarn install'
|
||||
include:
|
||||
- 'doc/**/*.md'
|
||||
Vale:
|
||||
enabled: true
|
||||
description: 'Lint documentation for grammatical and formatting errors'
|
||||
required_executable: 'vale'
|
||||
flags: ['--config', '.vale.ini', '--minAlertLevel', 'error', 'doc']
|
||||
install_command: 'brew install vale # (or use another package manager)'
|
||||
include:
|
||||
- 'doc/**/*.md'
|
||||
|
||||
CommitMsg:
|
||||
TextWidth:
|
||||
|
|
30
.rubocop.yml
30
.rubocop.yml
|
@ -9,6 +9,7 @@ require:
|
|||
inherit_from:
|
||||
- .rubocop_todo.yml
|
||||
- ./rubocop/rubocop-migrations.yml
|
||||
- ./rubocop/rubocop-usage-data.yml
|
||||
|
||||
inherit_mode:
|
||||
merge:
|
||||
|
@ -335,6 +336,15 @@ Graphql/AuthorizeTypes:
|
|||
- 'spec/**/*.rb'
|
||||
- 'ee/spec/**/*.rb'
|
||||
|
||||
Graphql/JSONType:
|
||||
Enabled: true
|
||||
Include:
|
||||
- 'app/graphql/**/*'
|
||||
- 'ee/app/graphql/**/*'
|
||||
Exclude:
|
||||
- 'spec/**/*.rb'
|
||||
- 'ee/spec/**/*.rb'
|
||||
|
||||
RSpec/EnvAssignment:
|
||||
Enable: true
|
||||
Include:
|
||||
|
@ -433,6 +443,11 @@ RSpec/HaveGitlabHttpStatus:
|
|||
Style/MultilineWhenThen:
|
||||
Enabled: false
|
||||
|
||||
# We use EnforcedStyle of comparison here due to it being better
|
||||
# performing code as seen in https://gitlab.com/gitlab-org/gitlab/-/merge_requests/36221#note_375659681
|
||||
Style/NumericPredicate:
|
||||
EnforcedStyle: comparison
|
||||
|
||||
Style/FloatDivision:
|
||||
Enabled: false
|
||||
|
||||
|
@ -455,8 +470,10 @@ Rails/TimeZone:
|
|||
Include:
|
||||
- 'app/controllers/**/*'
|
||||
- 'app/services/**/*'
|
||||
- 'lib/**/*'
|
||||
- 'spec/controllers/**/*'
|
||||
- 'spec/services/**/*'
|
||||
- 'spec/lib/**/*'
|
||||
- 'ee/app/controllers/**/*'
|
||||
- 'ee/app/services/**/*'
|
||||
- 'ee/spec/controllers/**/*'
|
||||
|
@ -469,7 +486,8 @@ Rails/TimeZone:
|
|||
- 'spec/workers/**/*'
|
||||
- 'ee/app/workers/**/*'
|
||||
- 'ee/spec/workers/**/*'
|
||||
|
||||
- 'ee/lib/**/*'
|
||||
- 'ee/spec/lib/**/*'
|
||||
|
||||
# WIP: See https://gitlab.com/gitlab-org/gitlab/-/issues/220040
|
||||
Rails/SaveBang:
|
||||
|
@ -481,3 +499,13 @@ Rails/SaveBang:
|
|||
- 'ee/spec/**/*.rb'
|
||||
- 'qa/spec/**/*.rb'
|
||||
- 'qa/qa/specs/**/*.rb'
|
||||
|
||||
Cop/PutProjectRoutesUnderScope:
|
||||
Include:
|
||||
- 'config/routes/project.rb'
|
||||
- 'ee/config/routes/project.rb'
|
||||
|
||||
Cop/PutGroupRoutesUnderScope:
|
||||
Include:
|
||||
- 'config/routes/group.rb'
|
||||
- 'ee/config/routes/group.rb'
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
# This configuration was generated by
|
||||
# `rubocop --auto-gen-config`
|
||||
# on 2020-05-20 16:32:14 -0400 using RuboCop version 0.82.0.
|
||||
# `rubocop --auto-gen-config --exclude-limit 10000`
|
||||
# on 2020-08-17 21:05:54 +1200 using RuboCop version 0.82.0.
|
||||
# The point is for the user to remove these configuration records
|
||||
# one by one as the offenses are removed from the code base.
|
||||
# Note that changes in the inspected code, or installation of new
|
||||
|
@ -25,7 +25,6 @@ Layout/ClosingHeredocIndentation:
|
|||
- 'app/graphql/mutations/merge_requests/set_wip.rb'
|
||||
- 'ee/db/geo/migrate/20180322062741_migrate_ci_job_artifacts_to_separate_registry.rb'
|
||||
- 'ee/lib/gitlab/geo/health_check.rb'
|
||||
- 'lib/gitlab/background_migration/populate_untracked_uploads.rb'
|
||||
- 'spec/features/merge_request/user_sees_diff_spec.rb'
|
||||
- 'spec/lib/gitlab/asciidoc_spec.rb'
|
||||
- 'spec/lib/gitlab/checks/project_moved_spec.rb'
|
||||
|
@ -154,23 +153,6 @@ Layout/SpaceInsideBlockBraces:
|
|||
Layout/SpaceInsideParens:
|
||||
Enabled: false
|
||||
|
||||
# Offense count: 19
|
||||
Lint/DuplicateMethods:
|
||||
Exclude:
|
||||
- 'app/models/commit.rb'
|
||||
- 'app/models/note.rb'
|
||||
- 'lib/bitbucket/representation/repo.rb'
|
||||
- 'lib/declarative_policy/base.rb'
|
||||
- 'lib/gitlab/auth/ldap/person.rb'
|
||||
- 'lib/gitlab/auth/o_auth/user.rb'
|
||||
- 'lib/gitlab/ci/build/artifacts/metadata/entry.rb'
|
||||
- 'lib/gitlab/cycle_analytics/base_event_fetcher.rb'
|
||||
- 'lib/gitlab/diff/formatters/base_formatter.rb'
|
||||
- 'lib/gitlab/git/blob.rb'
|
||||
- 'lib/gitlab/git/repository.rb'
|
||||
- 'lib/gitlab/git/tree.rb'
|
||||
- 'lib/gitlab/git/wiki_page.rb'
|
||||
|
||||
# Offense count: 157
|
||||
# Configuration parameters: MaximumRangeSize.
|
||||
Lint/MissingCopEnableDirective:
|
||||
|
@ -275,7 +257,6 @@ Performance/Count:
|
|||
Exclude:
|
||||
- 'app/helpers/groups_helper.rb'
|
||||
- 'app/services/merge_requests/add_context_service.rb'
|
||||
- 'ee/lib/gitlab/geo/fdw.rb'
|
||||
- 'ee/lib/gitlab/graphql/aggregations/epics/epic_node.rb'
|
||||
- 'ee/spec/controllers/projects/feature_flags_controller_spec.rb'
|
||||
- 'ee/spec/requests/api/feature_flags_spec.rb'
|
||||
|
@ -303,11 +284,6 @@ Performance/Detect:
|
|||
RSpec/ContextWording:
|
||||
Enabled: false
|
||||
|
||||
# Offense count: 626
|
||||
# Cop supports --auto-correct.
|
||||
RSpec/EmptyLineAfterLetBlock:
|
||||
Enabled: false
|
||||
|
||||
# Offense count: 1121
|
||||
# Cop supports --auto-correct.
|
||||
# Configuration parameters: EnforcedStyle.
|
||||
|
@ -472,6 +448,166 @@ Rails/RakeEnvironment:
|
|||
Rails/SkipsModelValidations:
|
||||
Enabled: false
|
||||
|
||||
# Offense count: 308
|
||||
# Cop supports --auto-correct.
|
||||
# Configuration parameters: EnforcedStyle.
|
||||
# SupportedStyles: strict, flexible
|
||||
Rails/TimeZone:
|
||||
Enabled: true
|
||||
Exclude:
|
||||
- 'lib/gitlab/popen.rb'
|
||||
- 'ee/lib/delay.rb'
|
||||
- 'ee/lib/gitlab/elastic/helper.rb'
|
||||
- 'ee/lib/gitlab/elastic/indexer.rb'
|
||||
- 'ee/lib/gitlab/geo/base_request.rb'
|
||||
- 'ee/lib/gitlab/geo/event_gap_tracking.rb'
|
||||
- 'ee/lib/gitlab/geo/log_cursor/events/design_repository_updated_event.rb'
|
||||
- 'ee/lib/gitlab/geo/log_cursor/events/repository_updated_event.rb'
|
||||
- 'ee/lib/gitlab/geo/log_cursor/logger.rb'
|
||||
- 'ee/lib/gitlab/geo/oauth/login_state.rb'
|
||||
- 'ee/lib/gitlab/prometheus/queries/cluster_query.rb'
|
||||
- 'ee/lib/gitlab/prometheus/queries/packet_flow_query.rb'
|
||||
- 'ee/spec/lib/ee/gitlab/checks/push_rules/commit_check_spec.rb'
|
||||
- 'ee/spec/lib/ee/gitlab/ci/pipeline/quota/job_activity_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/analytics/cycle_analytics/data_collector_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/analytics/cycle_analytics/summary/group/stage_summary_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/analytics/cycle_analytics/summary/group/stage_time_summary_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/auth/ldap/access_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/auth/smartcard/san_extension_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/auth/smartcard/session_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/background_migration/fix_orphan_promoted_issues_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/ci/pipeline/chain/limit/job_activity_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/elastic/client_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/base_request_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/cache_invalidation_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/container_repository_updated_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/design_repository_updated_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/hashed_storage_attachments_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/hashed_storage_migrated_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/job_artifact_deleted_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/lfs_object_deleted_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/repositories_changed_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/repository_created_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/repository_deleted_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/repository_renamed_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/repository_updated_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/reset_checksum_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/events/upload_deleted_event_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/geo/log_cursor/logger_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/git_access_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/prometheus/queries/additional_metrics_deployment_query_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/prometheus/queries/cluster_query_spec.rb'
|
||||
- 'ee/spec/lib/gitlab/prometheus/queries/packet_flow_query_spec.rb'
|
||||
- 'lib/api/helpers.rb'
|
||||
- 'lib/api/sidekiq_metrics.rb'
|
||||
- 'lib/backup/manager.rb'
|
||||
- 'lib/bitbucket_server/representation/base.rb'
|
||||
- 'lib/gitlab/auth/current_user_mode.rb'
|
||||
- 'lib/gitlab/auth/ldap/access.rb'
|
||||
- 'lib/gitlab/chaos.rb'
|
||||
- 'lib/gitlab/checks/timed_logger.rb'
|
||||
- 'lib/gitlab/ci/ansi2json/line.rb'
|
||||
- 'lib/gitlab/ci/pipeline/chain/sequence.rb'
|
||||
- 'lib/gitlab/ci/pipeline/duration.rb'
|
||||
- 'lib/gitlab/cycle_analytics/summary/deployment_frequency.rb'
|
||||
- 'lib/gitlab/database.rb'
|
||||
- 'lib/gitlab/external_authorization/access.rb'
|
||||
- 'lib/gitlab/external_authorization/cache.rb'
|
||||
- 'lib/gitlab/gitaly_client.rb'
|
||||
- 'lib/gitlab/gitaly_client/ref_service.rb'
|
||||
- 'lib/gitlab/github_import/representation.rb'
|
||||
- 'lib/gitlab/grape_logging/loggers/queue_duration_logger.rb'
|
||||
- 'lib/gitlab/health_checks/base_abstract_check.rb'
|
||||
- 'lib/gitlab/import_export.rb'
|
||||
- 'lib/gitlab/instrumentation/elasticsearch_transport.rb'
|
||||
- 'lib/gitlab/instrumentation/redis_interceptor.rb'
|
||||
- 'lib/gitlab/instrumentation_helper.rb'
|
||||
- 'lib/gitlab/kubernetes/helm/certificate.rb'
|
||||
- 'lib/gitlab/lfs_token.rb'
|
||||
- 'lib/gitlab/loop_helpers.rb'
|
||||
- 'lib/gitlab/phabricator_import/representation/task.rb'
|
||||
- 'lib/gitlab/prometheus/queries/additional_metrics_environment_query.rb'
|
||||
- 'lib/gitlab/prometheus/queries/matched_metric_query.rb'
|
||||
- 'lib/gitlab/prometheus_client.rb'
|
||||
- 'lib/gitlab/sherlock/transaction.rb'
|
||||
- 'lib/gitlab/task_helpers.rb'
|
||||
- 'lib/gitlab/x509/tag.rb'
|
||||
- 'lib/grafana/time_window.rb'
|
||||
- 'lib/json_web_token/token.rb'
|
||||
- 'lib/object_storage/direct_upload.rb'
|
||||
- 'lib/quality/seeders/issues.rb'
|
||||
- 'lib/rspec_flaky/flaky_example.rb'
|
||||
- 'lib/rspec_flaky/report.rb'
|
||||
- 'lib/tasks/gitlab/assets.rake'
|
||||
- 'lib/tasks/gitlab/backup.rake'
|
||||
- 'lib/tasks/gitlab/cleanup.rake'
|
||||
- 'lib/tasks/gitlab/list_repos.rake'
|
||||
- 'spec/lib/api/helpers_spec.rb'
|
||||
- 'spec/lib/gitlab/analytics/cycle_analytics/base_query_builder_spec.rb'
|
||||
- 'spec/lib/gitlab/app_json_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/app_text_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/auth/current_user_mode_spec.rb'
|
||||
- 'spec/lib/gitlab/background_migration/recalculate_project_authorizations_spec.rb'
|
||||
- 'spec/lib/gitlab/background_migration/wrongfully_confirmed_email_unconfirmer_spec.rb'
|
||||
- 'spec/lib/gitlab/bitbucket_import/importer_spec.rb'
|
||||
- 'spec/lib/gitlab/bitbucket_server_import/importer_spec.rb'
|
||||
- 'spec/lib/gitlab/checks/timed_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/ci/cron_parser_spec.rb'
|
||||
- 'spec/lib/gitlab/cycle_analytics/stage_summary_spec.rb'
|
||||
- 'spec/lib/gitlab/cycle_analytics/usage_data_spec.rb'
|
||||
- 'spec/lib/gitlab/data_builder/note_spec.rb'
|
||||
- 'spec/lib/gitlab/database/background_migration_job_spec.rb'
|
||||
- 'spec/lib/gitlab/database_spec.rb'
|
||||
- 'spec/lib/gitlab/discussions_diff/file_collection_spec.rb'
|
||||
- 'spec/lib/gitlab/external_authorization/access_spec.rb'
|
||||
- 'spec/lib/gitlab/external_authorization/cache_spec.rb'
|
||||
- 'spec/lib/gitlab/external_authorization/logger_spec.rb'
|
||||
- 'spec/lib/gitlab/fogbugz_import/importer_spec.rb'
|
||||
- 'spec/lib/gitlab/git/branch_spec.rb'
|
||||
- 'spec/lib/gitlab/git/commit_spec.rb'
|
||||
- 'spec/lib/gitlab/git/repository_spec.rb'
|
||||
- 'spec/lib/gitlab/git_access_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/diff_note_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/issue_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/issues_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/milestones_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/note_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/pull_request_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/importer/releases_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/representation/diff_note_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/representation/issue_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/representation/note_spec.rb'
|
||||
- 'spec/lib/gitlab/github_import/representation/pull_request_spec.rb'
|
||||
- 'spec/lib/gitlab/grape_logging/formatters/lograge_with_timestamp_spec.rb'
|
||||
- 'spec/lib/gitlab/grape_logging/loggers/cloudflare_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/grape_logging/loggers/queue_duration_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/graphql_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/graphs/commits_spec.rb'
|
||||
- 'spec/lib/gitlab/import_export/project/relation_factory_spec.rb'
|
||||
- 'spec/lib/gitlab/instrumentation_helper_spec.rb'
|
||||
- 'spec/lib/gitlab/json_logger_spec.rb'
|
||||
- 'spec/lib/gitlab/lfs_token_spec.rb'
|
||||
- 'spec/lib/gitlab/log_timestamp_formatter_spec.rb'
|
||||
- 'spec/lib/gitlab/middleware/rails_queue_duration_spec.rb'
|
||||
- 'spec/lib/gitlab/omniauth_logging/json_formatter_spec.rb'
|
||||
- 'spec/lib/gitlab/phabricator_import/issues/task_importer_spec.rb'
|
||||
- 'spec/lib/gitlab/phabricator_import/representation/task_spec.rb'
|
||||
- 'spec/lib/gitlab/prometheus/queries/additional_metrics_deployment_query_spec.rb'
|
||||
- 'spec/lib/gitlab/prometheus/queries/deployment_query_spec.rb'
|
||||
- 'spec/lib/gitlab/prometheus/queries/validate_query_spec.rb'
|
||||
- 'spec/lib/gitlab/sherlock/transaction_spec.rb'
|
||||
- 'spec/lib/gitlab/sidekiq_logging/json_formatter_spec.rb'
|
||||
- 'spec/lib/gitlab/sidekiq_middleware/duplicate_jobs/strategies/until_executing_spec.rb'
|
||||
- 'spec/lib/gitlab/updated_notes_paginator_spec.rb'
|
||||
- 'spec/lib/gitlab/utils/json_size_estimator_spec.rb'
|
||||
- 'spec/lib/gitlab/x509/signature_spec.rb'
|
||||
- 'spec/lib/grafana/time_window_spec.rb'
|
||||
- 'spec/lib/json_web_token/hmac_token_spec.rb'
|
||||
- 'spec/lib/rspec_flaky/flaky_example_spec.rb'
|
||||
- 'spec/lib/rspec_flaky/listener_spec.rb'
|
||||
- 'spec/lib/rspec_flaky/report_spec.rb'
|
||||
|
||||
# Offense count: 8
|
||||
# Cop supports --auto-correct.
|
||||
Security/YAMLLoad:
|
||||
|
@ -620,123 +756,6 @@ Style/Next:
|
|||
Style/NumericLiteralPrefix:
|
||||
Enabled: false
|
||||
|
||||
# Offense count: 130
|
||||
# Cop supports --auto-correct.
|
||||
# Configuration parameters: AutoCorrect, EnforcedStyle, IgnoredMethods.
|
||||
# SupportedStyles: predicate, comparison
|
||||
# We use EnforcedStyle of comparison here due to it being better
|
||||
# performing code as seen https://gitlab.com/gitlab-org/gitlab/-/merge_requests/36221#note_375659681
|
||||
Style/NumericPredicate:
|
||||
EnforcedStyle: comparison
|
||||
Exclude:
|
||||
- 'spec/**/*'
|
||||
- 'app/views/**/*'
|
||||
- 'ee/app/views/**/*'
|
||||
- 'app/controllers/concerns/issuable_collections.rb'
|
||||
- 'app/controllers/concerns/paginated_collection.rb'
|
||||
- 'app/helpers/graph_helper.rb'
|
||||
- 'app/helpers/timeboxes_helper.rb'
|
||||
- 'app/models/ci/pipeline.rb'
|
||||
- 'app/models/ci/stage.rb'
|
||||
- 'app/models/concerns/update_project_statistics.rb'
|
||||
- 'app/models/merge_request_diff.rb'
|
||||
- 'app/models/milestone.rb'
|
||||
- 'app/models/network/graph.rb'
|
||||
- 'app/models/postgresql/replication_slot.rb'
|
||||
- 'app/models/project.rb'
|
||||
- 'app/models/suggestion.rb'
|
||||
- 'app/models/user.rb'
|
||||
- 'app/serializers/merge_request_widget_entity.rb'
|
||||
- 'app/services/boards/issues/move_service.rb'
|
||||
- 'app/services/cohorts_service.rb'
|
||||
- 'app/services/discussions/resolve_service.rb'
|
||||
- 'app/services/issues/reorder_service.rb'
|
||||
- 'app/services/notes/create_service.rb'
|
||||
- 'app/services/packages/nuget/metadata_extraction_service.rb'
|
||||
- 'app/services/packages/nuget/search_service.rb'
|
||||
- 'app/services/projects/auto_devops/disable_service.rb'
|
||||
- 'app/services/projects/update_pages_service.rb'
|
||||
- 'app/services/search_service.rb'
|
||||
- 'app/workers/admin_email_worker.rb'
|
||||
- 'app/workers/gitlab/import/advance_stage.rb'
|
||||
- 'config/initializers/validate_puma.rb'
|
||||
- 'ee/app/controllers/security/projects_controller.rb'
|
||||
- 'ee/app/graphql/mutations/instance_security_dashboard/remove_project.rb'
|
||||
- 'ee/app/helpers/ee/timeboxes_helper.rb'
|
||||
- 'ee/app/models/ci/minutes/quota.rb'
|
||||
- 'ee/app/models/ee/ci/runner.rb'
|
||||
- 'ee/app/models/geo_node_status.rb'
|
||||
- 'ee/app/models/license.rb'
|
||||
- 'ee/app/models/namespace_statistics.rb'
|
||||
- 'ee/app/services/ee/issues/base_service.rb'
|
||||
- 'ee/app/services/ee/merge_requests/approval_service.rb'
|
||||
- 'ee/app/services/ee/quick_actions/target_service.rb'
|
||||
- 'ee/app/services/elastic/indexing_control_service.rb'
|
||||
- 'ee/app/services/geo/hashed_storage_migration_service.rb'
|
||||
- 'ee/app/services/geo/prune_event_log_service.rb'
|
||||
- 'ee/app/services/security/waf_anomaly_summary_service.rb'
|
||||
- 'ee/app/services/update_build_minutes_service.rb'
|
||||
- 'ee/app/workers/geo/container_repository_sync_dispatch_worker.rb'
|
||||
- 'ee/app/workers/geo/file_download_dispatch_worker.rb'
|
||||
- 'ee/app/workers/geo/registry_sync_worker.rb'
|
||||
- 'ee/app/workers/geo/repository_shard_sync_worker.rb'
|
||||
- 'ee/app/workers/geo/repository_verification/primary/shard_worker.rb'
|
||||
- 'ee/lib/api/helpers/packages/conan/api_helpers.rb'
|
||||
- 'ee/lib/ee/gitlab/auth/ldap/person.rb'
|
||||
- 'ee/lib/ee/gitlab/background_migration/prune_orphaned_geo_events.rb'
|
||||
- 'ee/lib/ee/gitlab/checks/push_rules/file_size_check.rb'
|
||||
- 'ee/lib/ee/gitlab/geo_git_access.rb'
|
||||
- 'ee/lib/gitlab/geo/fdw.rb'
|
||||
- 'ee/lib/gitlab/geo/log_cursor/lease.rb'
|
||||
- 'ee/lib/tasks/gitlab/elastic.rake'
|
||||
- 'lib/api/entities/feature.rb'
|
||||
- 'lib/api/helpers/pagination_strategies.rb'
|
||||
- 'lib/backup/files.rb'
|
||||
- 'lib/banzai/filter/gollum_tags_filter.rb'
|
||||
- 'lib/bitbucket_server/paginator.rb'
|
||||
- 'lib/declarative_policy/runner.rb'
|
||||
- 'lib/gitlab/auth/ldap/adapter.rb'
|
||||
- 'lib/gitlab/bare_repository_import/importer.rb'
|
||||
- 'lib/gitlab/ci/config/external/context.rb'
|
||||
- 'lib/gitlab/ci/reports/accessibility_reports_comparer.rb'
|
||||
- 'lib/gitlab/cycle_analytics/summary/value.rb'
|
||||
- 'lib/gitlab/cycle_analytics/summary_helper.rb'
|
||||
- 'lib/gitlab/danger/teammate.rb'
|
||||
- 'lib/gitlab/database.rb'
|
||||
- 'lib/gitlab/database/connection_timer.rb'
|
||||
- 'lib/gitlab/database/migration_helpers.rb'
|
||||
- 'lib/gitlab/exclusive_lease.rb'
|
||||
- 'lib/gitlab/exclusive_lease_helpers/sleeping_lock.rb'
|
||||
- 'lib/gitlab/experimentation.rb'
|
||||
- 'lib/gitlab/file_hook.rb'
|
||||
- 'lib/gitlab/git/commit.rb'
|
||||
- 'lib/gitlab/git/repository.rb'
|
||||
- 'lib/gitlab/git/rugged_impl/blob.rb'
|
||||
- 'lib/gitlab/gitaly_client.rb'
|
||||
- 'lib/gitlab/github_import/user_finder.rb'
|
||||
- 'lib/gitlab/hashed_storage/migrator.rb'
|
||||
- 'lib/gitlab/import_export/command_line_util.rb'
|
||||
- 'lib/gitlab/multi_collection_paginator.rb'
|
||||
- 'lib/gitlab/polling_interval.rb'
|
||||
- 'lib/gitlab/project_search_results.rb'
|
||||
- 'lib/gitlab/seeder.rb'
|
||||
- 'lib/gitlab/sidekiq_cluster.rb'
|
||||
- 'lib/gitlab/sidekiq_daemon/memory_killer.rb'
|
||||
- 'lib/gitlab/sidekiq_middleware/memory_killer.rb'
|
||||
- 'lib/gitlab/sidekiq_status.rb'
|
||||
- 'lib/gitlab/slash_commands/presenters/issue_show.rb'
|
||||
- 'lib/gitlab/task_helpers.rb'
|
||||
- 'lib/gitlab/untrusted_regexp.rb'
|
||||
- 'lib/gitlab/utils.rb'
|
||||
- 'lib/system_check/sidekiq_check.rb'
|
||||
- 'lib/tasks/gitlab/gitaly.rake'
|
||||
- 'lib/tasks/gitlab/snippets.rake'
|
||||
- 'lib/tasks/gitlab/workhorse.rake'
|
||||
- 'qa/qa/git/repository.rb'
|
||||
- 'qa/qa/support/wait_for_requests.rb'
|
||||
- 'ee/app/models/ee/project.rb'
|
||||
- 'lib/gitlab/usage_data/topology.rb'
|
||||
|
||||
# Offense count: 117
|
||||
# Cop supports --auto-correct.
|
||||
Style/ParallelAssignment:
|
||||
|
@ -855,35 +874,8 @@ Rails/SaveBang:
|
|||
Exclude:
|
||||
- 'ee/spec/controllers/projects/merge_requests_controller_spec.rb'
|
||||
- 'ee/spec/controllers/subscriptions_controller_spec.rb'
|
||||
- 'ee/spec/factories/ci/job_artifacts.rb'
|
||||
- 'ee/spec/factories/epics.rb'
|
||||
- 'ee/spec/factories/licenses.rb'
|
||||
- 'ee/spec/factories/merge_requests.rb'
|
||||
- 'ee/spec/features/admin/admin_users_spec.rb'
|
||||
- 'ee/spec/features/admin/geo/admin_geo_nodes_spec.rb'
|
||||
- 'ee/spec/features/admin/licenses/admin_views_license_spec.rb'
|
||||
- 'ee/spec/features/boards/scoped_issue_board_spec.rb'
|
||||
- 'ee/spec/features/ci_shared_runner_warnings_spec.rb'
|
||||
- 'ee/spec/features/dashboards/operations_spec.rb'
|
||||
- 'ee/spec/features/issues/gfm_autocomplete_ee_spec.rb'
|
||||
- 'ee/spec/features/merge_request/user_approves_spec.rb'
|
||||
- 'ee/spec/features/merge_requests/user_views_all_merge_requests_spec.rb'
|
||||
- 'ee/spec/features/projects/members/invite_group_and_members_spec.rb'
|
||||
- 'ee/spec/features/projects/merge_requests/user_approves_merge_request_spec.rb'
|
||||
- 'ee/spec/features/projects/mirror_spec.rb'
|
||||
- 'ee/spec/features/projects/new_project_spec.rb'
|
||||
- 'ee/spec/features/projects/settings/user_manages_approval_settings_spec.rb'
|
||||
- 'ee/spec/features/projects/settings/user_manages_members_spec.rb'
|
||||
- 'ee/spec/features/search/elastic/global_search_spec.rb'
|
||||
- 'ee/spec/features/security/project/internal_access_spec.rb'
|
||||
- 'ee/spec/features/security/project/public_access_spec.rb'
|
||||
- 'ee/spec/finders/epics_finder_spec.rb'
|
||||
- 'ee/spec/finders/security/vulnerabilities_finder_spec.rb'
|
||||
- 'ee/spec/frontend/fixtures/analytics.rb'
|
||||
- 'ee/spec/graphql/resolvers/vulnerabilities_resolver_spec.rb'
|
||||
- 'ee/spec/helpers/application_helper_spec.rb'
|
||||
- 'ee/spec/helpers/ee/dashboard_helper_spec.rb'
|
||||
- 'ee/spec/helpers/ee/issues_helper_spec.rb'
|
||||
- 'ee/spec/initializers/fog_google_https_private_urls_spec.rb'
|
||||
- 'ee/spec/lib/analytics/merge_request_metrics_calculator_spec.rb'
|
||||
- 'ee/spec/lib/ee/gitlab/auth/ldap/sync/group_spec.rb'
|
||||
|
@ -962,11 +954,6 @@ Rails/SaveBang:
|
|||
- 'ee/spec/models/visible_approvable_spec.rb'
|
||||
- 'ee/spec/models/vulnerabilities/feedback_spec.rb'
|
||||
- 'ee/spec/models/vulnerabilities/issue_link_spec.rb'
|
||||
- 'ee/spec/policies/group_policy_spec.rb'
|
||||
- 'ee/spec/policies/note_policy_spec.rb'
|
||||
- 'ee/spec/policies/project_policy_spec.rb'
|
||||
- 'ee/spec/policies/protected_branch_policy_spec.rb'
|
||||
- 'ee/spec/policies/vulnerabilities/feedback_policy_spec.rb'
|
||||
- 'ee/spec/presenters/audit_event_presenter_spec.rb'
|
||||
- 'ee/spec/presenters/epic_presenter_spec.rb'
|
||||
- 'ee/spec/requests/api/boards_spec.rb'
|
||||
|
@ -1035,7 +1022,6 @@ Rails/SaveBang:
|
|||
- 'ee/spec/services/todo_service_spec.rb'
|
||||
- 'ee/spec/services/update_build_minutes_service_spec.rb'
|
||||
- 'ee/spec/services/vulnerability_feedback/create_service_spec.rb'
|
||||
- 'ee/spec/support/helpers/ee/geo_helpers.rb'
|
||||
- 'ee/spec/support/protected_tags/access_control_shared_examples.rb'
|
||||
- 'ee/spec/support/shared_examples/features/protected_branches_access_control_shared_examples.rb'
|
||||
- 'ee/spec/support/shared_examples/finders/geo/framework_registry_finder_shared_examples.rb'
|
||||
|
@ -1051,7 +1037,6 @@ Rails/SaveBang:
|
|||
- 'ee/spec/support/shared_examples/requests/api/project_approval_rules_api_shared_examples.rb'
|
||||
- 'ee/spec/support/shared_examples/services/build_execute_shared_examples.rb'
|
||||
- 'ee/spec/support/shared_examples/services/issue_epic_shared_examples.rb'
|
||||
- 'ee/spec/views/layouts/nav/sidebar/_project.html.haml_spec.rb'
|
||||
- 'ee/spec/workers/adjourned_project_deletion_worker_spec.rb'
|
||||
- 'ee/spec/workers/clear_shared_runners_minutes_worker_spec.rb'
|
||||
- 'ee/spec/workers/create_github_webhook_worker_spec.rb'
|
||||
|
@ -1100,19 +1085,6 @@ Rails/SaveBang:
|
|||
- 'spec/controllers/sent_notifications_controller_spec.rb'
|
||||
- 'spec/controllers/sessions_controller_spec.rb'
|
||||
- 'spec/controllers/users_controller_spec.rb'
|
||||
- 'spec/factories/alert_management/alerts.rb'
|
||||
- 'spec/factories/boards.rb'
|
||||
- 'spec/factories/ci/pipelines.rb'
|
||||
- 'spec/factories/design_management/designs.rb'
|
||||
- 'spec/factories/design_management/versions.rb'
|
||||
- 'spec/factories/emails.rb'
|
||||
- 'spec/factories/issues.rb'
|
||||
- 'spec/factories/labels.rb'
|
||||
- 'spec/factories/merge_requests.rb'
|
||||
- 'spec/factories/plans.rb'
|
||||
- 'spec/factories/projects.rb'
|
||||
- 'spec/factories/services.rb'
|
||||
- 'spec/factories/wiki_pages.rb'
|
||||
- 'spec/factories_spec.rb'
|
||||
- 'spec/features/admin/admin_appearance_spec.rb'
|
||||
- 'spec/features/admin/admin_labels_spec.rb'
|
||||
|
@ -1142,14 +1114,6 @@ Rails/SaveBang:
|
|||
- 'spec/features/issues/user_filters_issues_spec.rb'
|
||||
- 'spec/features/issues/user_sees_live_update_spec.rb'
|
||||
- 'spec/features/issues/user_sorts_issues_spec.rb'
|
||||
- 'spec/features/merge_request/user_merges_when_pipeline_succeeds_spec.rb'
|
||||
- 'spec/features/merge_request/user_posts_diff_notes_spec.rb'
|
||||
- 'spec/features/merge_request/user_resolves_diff_notes_and_discussions_resolve_spec.rb'
|
||||
- 'spec/features/merge_request/user_sees_cherry_pick_modal_spec.rb'
|
||||
- 'spec/features/merge_request/user_sees_discussions_spec.rb'
|
||||
- 'spec/features/merge_request/user_sees_merge_widget_spec.rb'
|
||||
- 'spec/features/merge_request/user_sees_versions_spec.rb'
|
||||
- 'spec/features/merge_requests/user_mass_updates_spec.rb'
|
||||
- 'spec/features/profiles/emails_spec.rb'
|
||||
- 'spec/features/profiles/password_spec.rb'
|
||||
- 'spec/features/profiles/personal_access_tokens_spec.rb'
|
||||
|
@ -1176,32 +1140,11 @@ Rails/SaveBang:
|
|||
- 'spec/features/security/project/public_access_spec.rb'
|
||||
- 'spec/features/users/login_spec.rb'
|
||||
- 'spec/features/users/show_spec.rb'
|
||||
- 'spec/finders/admin/projects_finder_spec.rb'
|
||||
- 'spec/finders/autocomplete/move_to_project_finder_spec.rb'
|
||||
- 'spec/finders/ci/pipelines_for_merge_request_finder_spec.rb'
|
||||
- 'spec/finders/group_descendants_finder_spec.rb'
|
||||
- 'spec/finders/group_projects_finder_spec.rb'
|
||||
- 'spec/finders/issues_finder_spec.rb'
|
||||
- 'spec/finders/joined_groups_finder_spec.rb'
|
||||
- 'spec/finders/merge_requests_finder_spec.rb'
|
||||
- 'spec/finders/personal_projects_finder_spec.rb'
|
||||
- 'spec/finders/projects_finder_spec.rb'
|
||||
- 'spec/finders/uploader_finder_spec.rb'
|
||||
- 'spec/frontend/fixtures/issues.rb'
|
||||
- 'spec/frontend/fixtures/merge_requests.rb'
|
||||
- 'spec/graphql/mutations/merge_requests/set_locked_spec.rb'
|
||||
- 'spec/graphql/mutations/merge_requests/set_wip_spec.rb'
|
||||
- 'spec/graphql/resolvers/boards_resolver_spec.rb'
|
||||
- 'spec/helpers/appearances_helper_spec.rb'
|
||||
- 'spec/helpers/auto_devops_helper_spec.rb'
|
||||
- 'spec/helpers/issuables_helper_spec.rb'
|
||||
- 'spec/helpers/issues_helper_spec.rb'
|
||||
- 'spec/helpers/members_helper_spec.rb'
|
||||
- 'spec/helpers/notes_helper_spec.rb'
|
||||
- 'spec/helpers/profiles_helper_spec.rb'
|
||||
- 'spec/helpers/projects/alert_management_helper_spec.rb'
|
||||
- 'spec/helpers/projects_helper_spec.rb'
|
||||
- 'spec/helpers/visibility_level_helper_spec.rb'
|
||||
- 'spec/initializers/active_record_locking_spec.rb'
|
||||
- 'spec/initializers/fog_google_https_private_urls_spec.rb'
|
||||
- 'spec/lib/after_commit_queue_spec.rb'
|
||||
|
@ -1412,13 +1355,6 @@ Rails/SaveBang:
|
|||
- 'spec/models/user_status_spec.rb'
|
||||
- 'spec/models/wiki_page/meta_spec.rb'
|
||||
- 'spec/models/wiki_page_spec.rb'
|
||||
- 'spec/policies/ci/build_policy_spec.rb'
|
||||
- 'spec/policies/ci/pipeline_policy_spec.rb'
|
||||
- 'spec/policies/ci/pipeline_schedule_policy_spec.rb'
|
||||
- 'spec/policies/group_policy_spec.rb'
|
||||
- 'spec/policies/issue_policy_spec.rb'
|
||||
- 'spec/policies/merge_request_policy_spec.rb'
|
||||
- 'spec/policies/project_policy_spec.rb'
|
||||
- 'spec/presenters/ci/build_runner_presenter_spec.rb'
|
||||
- 'spec/presenters/ci/trigger_presenter_spec.rb'
|
||||
- 'spec/presenters/packages/conan/package_presenter_spec.rb'
|
||||
|
@ -1528,15 +1464,8 @@ Rails/SaveBang:
|
|||
- 'spec/services/users/repair_ldap_blocked_service_spec.rb'
|
||||
- 'spec/services/verify_pages_domain_service_spec.rb'
|
||||
- 'spec/sidekiq/cron/job_gem_dependency_spec.rb'
|
||||
- 'spec/support/helpers/cycle_analytics_helpers.rb'
|
||||
- 'spec/support/helpers/design_management_test_helpers.rb'
|
||||
- 'spec/support/helpers/jira_service_helper.rb'
|
||||
- 'spec/support/helpers/login_helpers.rb'
|
||||
- 'spec/support/helpers/notification_helpers.rb'
|
||||
- 'spec/support/helpers/stub_object_storage.rb'
|
||||
- 'spec/support/migrations_helpers/cluster_helpers.rb'
|
||||
- 'spec/support/migrations_helpers/namespaces_helper.rb'
|
||||
- 'spec/support/migrations_helpers/track_untracked_uploads_helpers.rb'
|
||||
- 'spec/support/shared_contexts/email_shared_context.rb'
|
||||
- 'spec/support/shared_contexts/finders/group_projects_finder_shared_contexts.rb'
|
||||
- 'spec/support/shared_contexts/mailers/notify_shared_context.rb'
|
||||
|
@ -1554,7 +1483,6 @@ Rails/SaveBang:
|
|||
- 'spec/support/shared_examples/models/members_notifications_shared_example.rb'
|
||||
- 'spec/support/shared_examples/models/mentionable_shared_examples.rb'
|
||||
- 'spec/support/shared_examples/models/project_latest_successful_build_for_shared_examples.rb'
|
||||
- 'spec/support/shared_examples/models/relative_positioning_shared_examples.rb'
|
||||
- 'spec/support/shared_examples/models/slack_mattermost_notifications_shared_examples.rb'
|
||||
- 'spec/support/shared_examples/models/update_project_statistics_shared_examples.rb'
|
||||
- 'spec/support/shared_examples/models/with_uploads_shared_examples.rb'
|
||||
|
@ -1573,24 +1501,3 @@ Rails/SaveBang:
|
|||
- 'spec/tasks/gitlab/web_hook_rake_spec.rb'
|
||||
- 'spec/uploaders/file_uploader_spec.rb'
|
||||
- 'spec/uploaders/object_storage_spec.rb'
|
||||
- 'spec/views/notify/changed_milestone_email.html.haml_spec.rb'
|
||||
- 'spec/views/projects/imports/new.html.haml_spec.rb'
|
||||
- 'spec/views/projects/merge_requests/show.html.haml_spec.rb'
|
||||
- 'spec/views/shared/_label_row.html.haml_spec.rb'
|
||||
- 'spec/workers/concerns/project_export_options_spec.rb'
|
||||
- 'spec/workers/gitlab/import/stuck_project_import_jobs_worker_spec.rb'
|
||||
- 'spec/workers/gitlab/jira_import/stuck_jira_import_jobs_worker_spec.rb'
|
||||
- 'spec/workers/migrate_external_diffs_worker_spec.rb'
|
||||
- 'spec/workers/namespaceless_project_destroy_worker_spec.rb'
|
||||
- 'spec/workers/namespaces/root_statistics_worker_spec.rb'
|
||||
- 'spec/workers/pages_domain_verification_worker_spec.rb'
|
||||
- 'spec/workers/process_commit_worker_spec.rb'
|
||||
- 'spec/workers/propagate_integration_worker_spec.rb'
|
||||
- 'spec/workers/propagate_service_template_worker_spec.rb'
|
||||
- 'spec/workers/remove_unreferenced_lfs_objects_worker_spec.rb'
|
||||
- 'spec/workers/repository_check/single_repository_worker_spec.rb'
|
||||
- 'spec/workers/repository_cleanup_worker_spec.rb'
|
||||
- 'spec/workers/repository_import_worker_spec.rb'
|
||||
- 'spec/workers/repository_update_remote_mirror_worker_spec.rb'
|
||||
- 'spec/workers/stuck_ci_jobs_worker_spec.rb'
|
||||
- 'spec/workers/update_head_pipeline_for_merge_request_worker_spec.rb'
|
||||
|
|
|
@ -7,6 +7,7 @@ scss_files:
|
|||
|
||||
exclude:
|
||||
- 'app/assets/stylesheets/pages/emojis.scss'
|
||||
- 'app/assets/stylesheets/startup/startup-general.scss'
|
||||
|
||||
linters:
|
||||
# Reports when you use improper spacing around ! (the "bang") in !default,
|
||||
|
|
1159
CHANGELOG.md
1159
CHANGELOG.md
File diff suppressed because it is too large
Load diff
|
@ -1 +1 @@
|
|||
13.2.10
|
||||
13.3.8
|
|
@ -1 +1 @@
|
|||
2.4.0
|
||||
2.6.0
|
||||
|
|
|
@ -1 +1 @@
|
|||
1.21.0
|
||||
1.22.0
|
||||
|
|
|
@ -1 +1 @@
|
|||
13.3.0
|
||||
13.6.0
|
|
@ -1 +1 @@
|
|||
8.37.0
|
||||
8.39.0
|
||||
|
|
31
Gemfile
31
Gemfile
|
@ -41,7 +41,7 @@ gem 'omniauth-oauth2-generic', '~> 0.2.2'
|
|||
gem 'omniauth-saml', '~> 1.10'
|
||||
gem 'omniauth-shibboleth', '~> 1.3.0'
|
||||
gem 'omniauth-twitter', '~> 1.4'
|
||||
gem 'omniauth_crowd', '~> 2.2.0'
|
||||
gem 'omniauth_crowd', '~> 2.4.0'
|
||||
gem 'omniauth-authentiq', '~> 0.3.3'
|
||||
gem 'omniauth_openid_connect', '~> 0.3.5'
|
||||
gem 'omniauth-salesforce', '~> 1.0.5'
|
||||
|
@ -69,7 +69,7 @@ gem 'rubyzip', '~> 2.0.0', require: 'zip'
|
|||
gem 'acme-client', '~> 2.0', '>= 2.0.6'
|
||||
|
||||
# Browser detection
|
||||
gem 'browser', '~> 2.5'
|
||||
gem 'browser', '~> 4.2'
|
||||
|
||||
# GPG
|
||||
gem 'gpgme', '~> 2.0.19'
|
||||
|
@ -119,6 +119,7 @@ gem 'fog-local', '~> 0.6'
|
|||
gem 'fog-openstack', '~> 1.0'
|
||||
gem 'fog-rackspace', '~> 0.1.1'
|
||||
gem 'fog-aliyun', '~> 0.3'
|
||||
gem 'gitlab-fog-azure-rm', '~> 0.7', require: false
|
||||
|
||||
# for Google storage
|
||||
gem 'google-api-client', '~> 0.33'
|
||||
|
@ -133,8 +134,10 @@ gem 'seed-fu', '~> 2.3.7'
|
|||
gem 'elasticsearch-model', '~> 6.1'
|
||||
gem 'elasticsearch-rails', '~> 6.1', require: 'elasticsearch/rails/instrumentation'
|
||||
gem 'elasticsearch-api', '~> 6.8'
|
||||
gem 'aws-sdk'
|
||||
gem 'faraday_middleware-aws-signers-v4'
|
||||
gem 'aws-sdk-core', '~> 3'
|
||||
gem 'aws-sdk-cloudformation', '~> 1'
|
||||
gem 'aws-sdk-s3', '~> 1'
|
||||
gem 'faraday_middleware-aws-sigv4', '~>0.3.0'
|
||||
|
||||
# Markdown and HTML processing
|
||||
gem 'html-pipeline', '~> 2.12'
|
||||
|
@ -188,7 +191,7 @@ gem 'acts-as-taggable-on', '~> 6.0'
|
|||
# Background jobs
|
||||
gem 'sidekiq', '~> 5.2.7'
|
||||
gem 'sidekiq-cron', '~> 1.0'
|
||||
gem 'redis-namespace', '~> 1.6.0'
|
||||
gem 'redis-namespace', '~> 1.7.0'
|
||||
gem 'gitlab-sidekiq-fetcher', '0.5.2', require: 'sidekiq-reliable-fetch'
|
||||
|
||||
# Cron Parser
|
||||
|
@ -214,7 +217,7 @@ gem 're2', '~> 1.2.0'
|
|||
gem 'version_sorter', '~> 2.2.4'
|
||||
|
||||
# Export Ruby Regex to Javascript
|
||||
gem 'js_regex', '~> 3.1'
|
||||
gem 'js_regex', '~> 3.4'
|
||||
|
||||
# User agent parsing
|
||||
gem 'device_detector'
|
||||
|
@ -328,7 +331,7 @@ group :metrics do
|
|||
gem 'method_source', '~> 0.8', require: false
|
||||
|
||||
# Prometheus
|
||||
gem 'prometheus-client-mmap', '~> 0.10.0'
|
||||
gem 'prometheus-client-mmap', '~> 0.11.0'
|
||||
gem 'raindrops', '~> 0.18'
|
||||
end
|
||||
|
||||
|
@ -404,7 +407,7 @@ group :test do
|
|||
gem 'rspec_profiling', '~> 0.0.5'
|
||||
gem 'rspec-parameterized', require: false
|
||||
|
||||
gem 'capybara', '~> 3.22.0'
|
||||
gem 'capybara', '~> 3.33.0'
|
||||
gem 'capybara-screenshot', '~> 1.0.22'
|
||||
gem 'selenium-webdriver', '~> 3.142'
|
||||
|
||||
|
@ -413,7 +416,7 @@ group :test do
|
|||
gem 'webmock', '~> 3.5.1'
|
||||
gem 'rails-controller-testing'
|
||||
gem 'concurrent-ruby', '~> 1.1'
|
||||
gem 'test-prof', '~> 0.10.0'
|
||||
gem 'test-prof', '~> 0.12.0'
|
||||
gem 'rspec_junit_formatter'
|
||||
gem 'guard-rspec'
|
||||
|
||||
|
@ -440,7 +443,7 @@ gem 'activerecord-explain-analyze', '~> 0.1', require: false
|
|||
gem 'oauth2', '~> 1.4'
|
||||
|
||||
# Health check
|
||||
gem 'health_check', '~> 2.6.0'
|
||||
gem 'health_check', '~> 3.0'
|
||||
|
||||
# System information
|
||||
gem 'vmstat', '~> 2.3.0'
|
||||
|
@ -460,11 +463,11 @@ group :ed25519 do
|
|||
end
|
||||
|
||||
# Gitaly GRPC protocol definitions
|
||||
gem 'gitaly', '~> 13.2.0.pre.rc2'
|
||||
gem 'gitaly', '~> 13.3.0-rc1'
|
||||
|
||||
gem 'grpc', '~> 1.24.0'
|
||||
gem 'grpc', '~> 1.30.2'
|
||||
|
||||
gem 'google-protobuf', '~> 3.8.0'
|
||||
gem 'google-protobuf', '~> 3.12'
|
||||
|
||||
gem 'toml-rb', '~> 1.0.0'
|
||||
|
||||
|
@ -505,5 +508,7 @@ gem 'valid_email', '~> 0.1'
|
|||
# JSON
|
||||
gem 'json', '~> 2.3.0'
|
||||
gem 'json-schema', '~> 2.8.0'
|
||||
gem 'json_schemer', '~> 0.2.12'
|
||||
gem 'oj', '~> 3.10.6'
|
||||
gem 'multi_json', '~> 1.14.1'
|
||||
gem 'yajl-ruby', '~> 1.4.1', require: 'yajl'
|
||||
|
|
144
Gemfile.lock
144
Gemfile.lock
|
@ -93,16 +93,34 @@ GEM
|
|||
encryptor (~> 3.0.0)
|
||||
attr_required (1.0.1)
|
||||
awesome_print (1.8.0)
|
||||
aws-eventstream (1.0.3)
|
||||
aws-sdk (2.11.374)
|
||||
aws-sdk-resources (= 2.11.374)
|
||||
aws-sdk-core (2.11.374)
|
||||
aws-sigv4 (~> 1.0)
|
||||
aws-eventstream (1.1.0)
|
||||
aws-partitions (1.345.0)
|
||||
aws-sdk-cloudformation (1.41.0)
|
||||
aws-sdk-core (~> 3, >= 3.99.0)
|
||||
aws-sigv4 (~> 1.1)
|
||||
aws-sdk-core (3.104.3)
|
||||
aws-eventstream (~> 1, >= 1.0.2)
|
||||
aws-partitions (~> 1, >= 1.239.0)
|
||||
aws-sigv4 (~> 1.1)
|
||||
jmespath (~> 1.0)
|
||||
aws-sdk-resources (2.11.374)
|
||||
aws-sdk-core (= 2.11.374)
|
||||
aws-sigv4 (1.1.0)
|
||||
aws-eventstream (~> 1.0, >= 1.0.2)
|
||||
aws-sdk-kms (1.36.0)
|
||||
aws-sdk-core (~> 3, >= 3.99.0)
|
||||
aws-sigv4 (~> 1.1)
|
||||
aws-sdk-s3 (1.75.0)
|
||||
aws-sdk-core (~> 3, >= 3.104.1)
|
||||
aws-sdk-kms (~> 1)
|
||||
aws-sigv4 (~> 1.1)
|
||||
aws-sigv4 (1.2.1)
|
||||
aws-eventstream (~> 1, >= 1.0.2)
|
||||
azure-core (0.1.15)
|
||||
faraday (~> 0.9)
|
||||
faraday_middleware (~> 0.10)
|
||||
nokogiri (~> 1.6)
|
||||
azure-storage (0.15.0.preview)
|
||||
azure-core (~> 0.1)
|
||||
faraday (~> 0.9)
|
||||
faraday_middleware (~> 0.10)
|
||||
nokogiri (~> 1.6, >= 1.6.8)
|
||||
babosa (1.0.2)
|
||||
base32 (0.3.2)
|
||||
batch-loader (1.4.0)
|
||||
|
@ -125,7 +143,7 @@ GEM
|
|||
actionpack (>= 5.0)
|
||||
activemodel (>= 5.0)
|
||||
brakeman (4.2.1)
|
||||
browser (2.5.3)
|
||||
browser (4.2.0)
|
||||
builder (3.2.4)
|
||||
bullet (6.0.2)
|
||||
activesupport (>= 3.0.0)
|
||||
|
@ -134,7 +152,7 @@ GEM
|
|||
bundler (>= 1.2.0, < 3)
|
||||
thor (~> 0.18)
|
||||
byebug (9.1.0)
|
||||
capybara (3.22.0)
|
||||
capybara (3.33.0)
|
||||
addressable
|
||||
mini_mime (>= 0.1.3)
|
||||
nokogiri (~> 1.8)
|
||||
|
@ -149,7 +167,7 @@ GEM
|
|||
activemodel (>= 4.0.0)
|
||||
activesupport (>= 4.0.0)
|
||||
mime-types (>= 1.16)
|
||||
character_set (1.1.2)
|
||||
character_set (1.4.0)
|
||||
charlock_holmes (0.7.6)
|
||||
childprocess (3.0.0)
|
||||
chunky_png (1.3.5)
|
||||
|
@ -263,6 +281,8 @@ GEM
|
|||
dry-equalizer (~> 0.3)
|
||||
dry-inflector (~> 0.1, >= 0.1.2)
|
||||
dry-logic (~> 1.0, >= 1.0.2)
|
||||
ecma-re-validator (0.2.1)
|
||||
regexp_parser (~> 1.2)
|
||||
ed25519 (1.2.4)
|
||||
elasticsearch (6.8.0)
|
||||
elasticsearch-api (= 6.8.0)
|
||||
|
@ -302,13 +322,16 @@ GEM
|
|||
railties (>= 4.2.0)
|
||||
faraday (0.17.3)
|
||||
multipart-post (>= 1.2, < 3)
|
||||
faraday-cookie_jar (0.0.6)
|
||||
faraday (>= 0.7.4)
|
||||
http-cookie (~> 1.0.0)
|
||||
faraday-http-cache (2.0.0)
|
||||
faraday (~> 0.8)
|
||||
faraday_middleware (0.14.0)
|
||||
faraday (>= 0.7.4, < 1.0)
|
||||
faraday_middleware-aws-signers-v4 (0.1.7)
|
||||
aws-sdk-resources (~> 2)
|
||||
faraday (~> 0.9)
|
||||
faraday_middleware-aws-sigv4 (0.3.0)
|
||||
aws-sigv4 (~> 1.0)
|
||||
faraday (>= 0.15)
|
||||
faraday_middleware-multi_json (0.0.6)
|
||||
faraday_middleware
|
||||
multi_json
|
||||
|
@ -391,11 +414,17 @@ GEM
|
|||
po_to_json (>= 1.0.0)
|
||||
rails (>= 3.2.0)
|
||||
git (1.5.0)
|
||||
gitaly (13.2.0.pre.rc2)
|
||||
gitaly (13.3.0.pre.rc2)
|
||||
grpc (~> 1.0)
|
||||
github-markup (1.7.0)
|
||||
gitlab-chronic (0.10.5)
|
||||
numerizer (~> 0.2)
|
||||
gitlab-fog-azure-rm (0.7.0)
|
||||
azure-storage (~> 0.15.0.preview)
|
||||
fog-core (= 2.1.0)
|
||||
fog-json (~> 1.2.0)
|
||||
mime-types
|
||||
ms_rest_azure (~> 0.12.0)
|
||||
gitlab-labkit (0.12.1)
|
||||
actionpack (>= 5.0.0, < 6.1.0)
|
||||
activesupport (>= 5.0.0, < 6.1.0)
|
||||
|
@ -441,9 +470,9 @@ GEM
|
|||
representable (~> 3.0)
|
||||
retriable (>= 2.0, < 4.0)
|
||||
signet (~> 0.12)
|
||||
google-protobuf (3.8.0)
|
||||
googleapis-common-protos-types (1.0.4)
|
||||
google-protobuf (~> 3.0)
|
||||
google-protobuf (3.12.4)
|
||||
googleapis-common-protos-types (1.0.5)
|
||||
google-protobuf (~> 3.11)
|
||||
googleauth (0.12.0)
|
||||
faraday (>= 0.17.3, < 2.0)
|
||||
jwt (>= 1.4, < 3.0)
|
||||
|
@ -482,8 +511,8 @@ GEM
|
|||
graphql (~> 1.6)
|
||||
html-pipeline (~> 2.8)
|
||||
sass (~> 3.4)
|
||||
grpc (1.24.0)
|
||||
google-protobuf (~> 3.8)
|
||||
grpc (1.30.2)
|
||||
google-protobuf (~> 3.12)
|
||||
googleapis-common-protos-types (~> 1.0)
|
||||
gssapi (1.2.0)
|
||||
ffi (>= 1.0.1)
|
||||
|
@ -513,13 +542,14 @@ GEM
|
|||
temple (>= 0.8.2)
|
||||
thor
|
||||
tilt
|
||||
hana (1.3.6)
|
||||
hangouts-chat (0.0.5)
|
||||
hashdiff (0.3.8)
|
||||
hashie (3.6.0)
|
||||
hashie-forbidden_attributes (0.1.1)
|
||||
hashie (>= 3.0)
|
||||
health_check (2.6.0)
|
||||
rails (>= 4.0)
|
||||
health_check (3.0.0)
|
||||
railties (>= 5.0)
|
||||
heapy (0.1.4)
|
||||
hipchat (1.5.2)
|
||||
httparty
|
||||
|
@ -562,9 +592,9 @@ GEM
|
|||
multipart-post
|
||||
oauth (~> 0.5, >= 0.5.0)
|
||||
jmespath (1.4.0)
|
||||
js_regex (3.1.1)
|
||||
character_set (~> 1.1)
|
||||
regexp_parser (~> 1.1)
|
||||
js_regex (3.4.0)
|
||||
character_set (~> 1.4)
|
||||
regexp_parser (~> 1.5)
|
||||
regexp_property_values (~> 0.3)
|
||||
json (2.3.0)
|
||||
json-jwt (1.11.0)
|
||||
|
@ -573,6 +603,11 @@ GEM
|
|||
bindata
|
||||
json-schema (2.8.0)
|
||||
addressable (>= 2.4)
|
||||
json_schemer (0.2.12)
|
||||
ecma-re-validator (~> 0.2)
|
||||
hana (~> 1.3)
|
||||
regexp_parser (~> 1.5)
|
||||
uri_template (~> 0.7)
|
||||
jwt (2.1.0)
|
||||
kaminari (1.2.1)
|
||||
activesupport (>= 4.1.0)
|
||||
|
@ -642,15 +677,24 @@ GEM
|
|||
thread_safe (~> 0.3, >= 0.3.1)
|
||||
memory_profiler (0.9.14)
|
||||
method_source (0.9.2)
|
||||
mime-types (3.2.2)
|
||||
mime-types (3.3.1)
|
||||
mime-types-data (~> 3.2015)
|
||||
mime-types-data (3.2019.0331)
|
||||
mime-types-data (3.2020.0512)
|
||||
mimemagic (0.3.5)
|
||||
mini_histogram (0.1.3)
|
||||
mini_magick (4.9.5)
|
||||
mini_mime (1.0.2)
|
||||
mini_portile2 (2.4.0)
|
||||
minitest (5.11.3)
|
||||
ms_rest (0.7.6)
|
||||
concurrent-ruby (~> 1.0)
|
||||
faraday (>= 0.9, < 2.0.0)
|
||||
timeliness (~> 0.3.10)
|
||||
ms_rest_azure (0.12.0)
|
||||
concurrent-ruby (~> 1.0)
|
||||
faraday (>= 0.9, < 2.0.0)
|
||||
faraday-cookie_jar (~> 0.0.6)
|
||||
ms_rest (~> 0.7.6)
|
||||
msgpack (1.3.1)
|
||||
multi_json (1.14.1)
|
||||
multi_xml (0.6.0)
|
||||
|
@ -740,7 +784,7 @@ GEM
|
|||
omniauth-twitter (1.4.0)
|
||||
omniauth-oauth (~> 1.1)
|
||||
rack
|
||||
omniauth_crowd (2.2.3)
|
||||
omniauth_crowd (2.4.0)
|
||||
activesupport
|
||||
nokogiri (>= 1.4.4)
|
||||
omniauth (~> 1.0)
|
||||
|
@ -787,7 +831,7 @@ GEM
|
|||
parser
|
||||
unparser
|
||||
procto (0.0.3)
|
||||
prometheus-client-mmap (0.10.0)
|
||||
prometheus-client-mmap (0.11.0)
|
||||
pry (0.11.3)
|
||||
coderay (~> 1.1.0)
|
||||
method_source (~> 0.9.0)
|
||||
|
@ -877,7 +921,7 @@ GEM
|
|||
redis-activesupport (5.2.0)
|
||||
activesupport (>= 3, < 7)
|
||||
redis-store (>= 1.3, < 2)
|
||||
redis-namespace (1.6.0)
|
||||
redis-namespace (1.7.0)
|
||||
redis (>= 3.0.4)
|
||||
redis-rack (2.1.2)
|
||||
rack (>= 2.0.8, < 3)
|
||||
|
@ -889,7 +933,7 @@ GEM
|
|||
redis-store (1.8.1)
|
||||
redis (>= 4, < 5)
|
||||
regexp_parser (1.5.1)
|
||||
regexp_property_values (0.3.4)
|
||||
regexp_property_values (0.3.5)
|
||||
representable (3.0.4)
|
||||
declarative (< 0.1.0)
|
||||
declarative-option (< 0.2.0)
|
||||
|
@ -1076,7 +1120,7 @@ GEM
|
|||
temple (0.8.2)
|
||||
terminal-table (1.8.0)
|
||||
unicode-display_width (~> 1.1, >= 1.1.1)
|
||||
test-prof (0.10.0)
|
||||
test-prof (0.12.0)
|
||||
text (1.3.1)
|
||||
thin (1.7.2)
|
||||
daemons (~> 1.0, >= 1.0.9)
|
||||
|
@ -1087,6 +1131,7 @@ GEM
|
|||
thrift (0.11.0.0)
|
||||
tilt (2.0.10)
|
||||
timecop (0.9.1)
|
||||
timeliness (0.3.10)
|
||||
timfel-krb5-auth (0.8.3)
|
||||
toml (0.2.0)
|
||||
parslet (~> 1.8.0)
|
||||
|
@ -1126,6 +1171,7 @@ GEM
|
|||
equalizer (~> 0.0.9)
|
||||
parser (>= 2.6.5)
|
||||
procto (~> 0.0.2)
|
||||
uri_template (0.7.0)
|
||||
valid_email (0.1.3)
|
||||
activemodel
|
||||
mail (>= 2.6.1)
|
||||
|
@ -1162,6 +1208,7 @@ GEM
|
|||
xml-simple (1.1.5)
|
||||
xpath (3.2.0)
|
||||
nokogiri (~> 1.8)
|
||||
yajl-ruby (1.4.1)
|
||||
zeitwerk (2.3.0)
|
||||
|
||||
PLATFORMS
|
||||
|
@ -1183,7 +1230,9 @@ DEPENDENCIES
|
|||
atlassian-jwt (~> 0.2.0)
|
||||
attr_encrypted (~> 3.1.0)
|
||||
awesome_print
|
||||
aws-sdk
|
||||
aws-sdk-cloudformation (~> 1)
|
||||
aws-sdk-core (~> 3)
|
||||
aws-sdk-s3 (~> 1)
|
||||
babosa (~> 1.0.2)
|
||||
base32 (~> 0.3.0)
|
||||
batch-loader (~> 1.4.0)
|
||||
|
@ -1195,10 +1244,10 @@ DEPENDENCIES
|
|||
bootsnap (~> 1.4.6)
|
||||
bootstrap_form (~> 4.2.0)
|
||||
brakeman (~> 4.2)
|
||||
browser (~> 2.5)
|
||||
browser (~> 4.2)
|
||||
bullet (~> 6.0.2)
|
||||
bundler-audit (~> 0.6.1)
|
||||
capybara (~> 3.22.0)
|
||||
capybara (~> 3.33.0)
|
||||
capybara-screenshot (~> 1.0.22)
|
||||
carrierwave (~> 1.3)
|
||||
charlock_holmes (~> 0.7.5)
|
||||
|
@ -1230,7 +1279,7 @@ DEPENDENCIES
|
|||
escape_utils (~> 1.1)
|
||||
factory_bot_rails (~> 5.1.0)
|
||||
faraday (~> 0.12)
|
||||
faraday_middleware-aws-signers-v4
|
||||
faraday_middleware-aws-sigv4 (~> 0.3.0)
|
||||
fast_blank
|
||||
ffaker (~> 2.10)
|
||||
flipper (~> 0.17.1)
|
||||
|
@ -1251,9 +1300,10 @@ DEPENDENCIES
|
|||
gettext (~> 3.2.2)
|
||||
gettext_i18n_rails (~> 1.8.0)
|
||||
gettext_i18n_rails_js (~> 1.3)
|
||||
gitaly (~> 13.2.0.pre.rc2)
|
||||
gitaly (~> 13.3.0.pre.rc1)
|
||||
github-markup (~> 1.7.0)
|
||||
gitlab-chronic (~> 0.10.5)
|
||||
gitlab-fog-azure-rm (~> 0.7)
|
||||
gitlab-labkit (= 0.12.1)
|
||||
gitlab-license (~> 1.0)
|
||||
gitlab-mail_room (~> 0.0.6)
|
||||
|
@ -1267,7 +1317,7 @@ DEPENDENCIES
|
|||
gitlab_omniauth-ldap (~> 2.1.1)
|
||||
gon (~> 6.2)
|
||||
google-api-client (~> 0.33)
|
||||
google-protobuf (~> 3.8.0)
|
||||
google-protobuf (~> 3.12)
|
||||
gpgme (~> 2.0.19)
|
||||
grape (= 1.4.0)
|
||||
grape-entity (~> 0.7.1)
|
||||
|
@ -1276,14 +1326,14 @@ DEPENDENCIES
|
|||
graphiql-rails (~> 1.4.10)
|
||||
graphql (~> 1.10.5)
|
||||
graphql-docs (~> 1.6.0)
|
||||
grpc (~> 1.24.0)
|
||||
grpc (~> 1.30.2)
|
||||
gssapi
|
||||
guard-rspec
|
||||
haml_lint (~> 0.34.0)
|
||||
hamlit (~> 2.11.0)
|
||||
hangouts-chat (~> 0.0.5)
|
||||
hashie-forbidden_attributes
|
||||
health_check (~> 2.6.0)
|
||||
health_check (~> 3.0)
|
||||
hipchat (~> 1.5.0)
|
||||
html-pipeline (~> 2.12)
|
||||
html2text
|
||||
|
@ -1291,9 +1341,10 @@ DEPENDENCIES
|
|||
icalendar
|
||||
invisible_captcha (~> 0.12.1)
|
||||
jira-ruby (~> 2.0.0)
|
||||
js_regex (~> 3.1)
|
||||
js_regex (~> 3.4)
|
||||
json (~> 2.3.0)
|
||||
json-schema (~> 2.8.0)
|
||||
json_schemer (~> 0.2.12)
|
||||
jwt (~> 2.1.0)
|
||||
kaminari (~> 1.0)
|
||||
knapsack (~> 1.17)
|
||||
|
@ -1337,7 +1388,7 @@ DEPENDENCIES
|
|||
omniauth-saml (~> 1.10)
|
||||
omniauth-shibboleth (~> 1.3.0)
|
||||
omniauth-twitter (~> 1.4)
|
||||
omniauth_crowd (~> 2.2.0)
|
||||
omniauth_crowd (~> 2.4.0)
|
||||
omniauth_openid_connect (~> 0.3.5)
|
||||
org-ruby (~> 0.9.12)
|
||||
parallel (~> 1.19)
|
||||
|
@ -1345,7 +1396,7 @@ DEPENDENCIES
|
|||
pg (~> 1.1)
|
||||
png_quantizator (~> 0.2.1)
|
||||
premailer-rails (~> 1.10.3)
|
||||
prometheus-client-mmap (~> 0.10.0)
|
||||
prometheus-client-mmap (~> 0.11.0)
|
||||
pry-byebug (~> 3.5.1)
|
||||
pry-rails (~> 0.3.9)
|
||||
rack (~> 2.0.9)
|
||||
|
@ -1365,7 +1416,7 @@ DEPENDENCIES
|
|||
re2 (~> 1.2.0)
|
||||
recaptcha (~> 4.11)
|
||||
redis (~> 4.0)
|
||||
redis-namespace (~> 1.6.0)
|
||||
redis-namespace (~> 1.7.0)
|
||||
redis-rails (~> 5.0.2)
|
||||
request_store (~> 1.5)
|
||||
responders (~> 3.0)
|
||||
|
@ -1408,7 +1459,7 @@ DEPENDENCIES
|
|||
stackprof (~> 0.2.15)
|
||||
state_machines-activerecord (~> 0.6.0)
|
||||
sys-filesystem (~> 1.1.6)
|
||||
test-prof (~> 0.10.0)
|
||||
test-prof (~> 0.12.0)
|
||||
thin (~> 1.7.0)
|
||||
timecop (~> 0.9.1)
|
||||
toml-rb (~> 1.0.0)
|
||||
|
@ -1426,6 +1477,7 @@ DEPENDENCIES
|
|||
webmock (~> 3.5.1)
|
||||
webpack-rails (~> 0.9.10)
|
||||
wikicloth (= 0.8.1)
|
||||
yajl-ruby (~> 1.4.1)
|
||||
|
||||
BUNDLED WITH
|
||||
1.17.3
|
||||
|
|
2
VERSION
2
VERSION
|
@ -1 +1 @@
|
|||
13.2.10
|
||||
13.3.8
|
BIN
app/assets/images/mailers/approval/icon-merge-request-gray.gif
Normal file
BIN
app/assets/images/mailers/approval/icon-merge-request-gray.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 704 B |
|
@ -0,0 +1,49 @@
|
|||
<script>
|
||||
import { GlButton } from '@gitlab/ui';
|
||||
import { s__ } from '~/locale';
|
||||
import eventHub from '../event_hub';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlButton,
|
||||
},
|
||||
props: {
|
||||
commitsEmpty: {
|
||||
type: Boolean,
|
||||
required: false,
|
||||
default: false,
|
||||
},
|
||||
contextCommitsEmpty: {
|
||||
type: Boolean,
|
||||
required: true,
|
||||
},
|
||||
},
|
||||
computed: {
|
||||
buttonText() {
|
||||
return this.contextCommitsEmpty || this.commitsEmpty
|
||||
? s__('AddContextCommits|Add previously merged commits')
|
||||
: s__('AddContextCommits|Add/remove');
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
openModal() {
|
||||
eventHub.$emit('openModal');
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<gl-button
|
||||
:class="[
|
||||
{
|
||||
'ml-3': !contextCommitsEmpty,
|
||||
'mt-3': !commitsEmpty && contextCommitsEmpty,
|
||||
},
|
||||
]"
|
||||
:variant="commitsEmpty ? 'info' : 'default'"
|
||||
@click="openModal"
|
||||
>
|
||||
{{ buttonText }}
|
||||
</gl-button>
|
||||
</template>
|
|
@ -0,0 +1,279 @@
|
|||
<script>
|
||||
import { mapState, mapActions } from 'vuex';
|
||||
import { GlModal, GlTabs, GlTab, GlSearchBoxByType, GlSprintf } from '@gitlab/ui';
|
||||
import ReviewTabContainer from '~/add_context_commits_modal/components/review_tab_container.vue';
|
||||
import { s__ } from '~/locale';
|
||||
import eventHub from '../event_hub';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
import {
|
||||
findCommitIndex,
|
||||
setCommitStatus,
|
||||
removeIfReadyToBeRemoved,
|
||||
removeIfPresent,
|
||||
} from '../utils';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlModal,
|
||||
GlTabs,
|
||||
GlTab,
|
||||
ReviewTabContainer,
|
||||
GlSearchBoxByType,
|
||||
GlSprintf,
|
||||
},
|
||||
props: {
|
||||
contextCommitsPath: {
|
||||
type: String,
|
||||
required: true,
|
||||
},
|
||||
targetBranch: {
|
||||
type: String,
|
||||
required: true,
|
||||
},
|
||||
mergeRequestIid: {
|
||||
type: Number,
|
||||
required: true,
|
||||
},
|
||||
projectId: {
|
||||
type: Number,
|
||||
required: true,
|
||||
},
|
||||
},
|
||||
computed: {
|
||||
...mapState([
|
||||
'tabIndex',
|
||||
'isLoadingCommits',
|
||||
'commits',
|
||||
'commitsLoadingError',
|
||||
'isLoadingContextCommits',
|
||||
'contextCommits',
|
||||
'contextCommitsLoadingError',
|
||||
'selectedCommits',
|
||||
'searchText',
|
||||
'toRemoveCommits',
|
||||
]),
|
||||
currentTabIndex: {
|
||||
get() {
|
||||
return this.tabIndex;
|
||||
},
|
||||
set(newTabIndex) {
|
||||
this.setTabIndex(newTabIndex);
|
||||
},
|
||||
},
|
||||
selectedCommitsCount() {
|
||||
return this.selectedCommits.filter(selectedCommit => selectedCommit.isSelected).length;
|
||||
},
|
||||
shouldPurge() {
|
||||
return this.selectedCommitsCount !== this.selectedCommits.length;
|
||||
},
|
||||
uniqueCommits() {
|
||||
return this.selectedCommits.filter(
|
||||
selectedCommit =>
|
||||
selectedCommit.isSelected &&
|
||||
findCommitIndex(this.contextCommits, selectedCommit.short_id) === -1,
|
||||
);
|
||||
},
|
||||
disableSaveButton() {
|
||||
// We should have a minimum of one commit selected and that should not be in the context commits list or we should have a context commit to delete
|
||||
return (
|
||||
(this.selectedCommitsCount.length === 0 || this.uniqueCommits.length === 0) &&
|
||||
this.toRemoveCommits.length === 0
|
||||
);
|
||||
},
|
||||
},
|
||||
watch: {
|
||||
tabIndex(newTabIndex) {
|
||||
this.handleTabChange(newTabIndex);
|
||||
},
|
||||
},
|
||||
mounted() {
|
||||
eventHub.$on('openModal', this.openModal);
|
||||
this.setBaseConfig({
|
||||
contextCommitsPath: this.contextCommitsPath,
|
||||
mergeRequestIid: this.mergeRequestIid,
|
||||
projectId: this.projectId,
|
||||
});
|
||||
},
|
||||
beforeDestroy() {
|
||||
eventHub.$off('openModal', this.openModal);
|
||||
clearTimeout(this.timeout);
|
||||
this.timeout = null;
|
||||
},
|
||||
methods: {
|
||||
...mapActions([
|
||||
'setBaseConfig',
|
||||
'setTabIndex',
|
||||
'searchCommits',
|
||||
'setCommits',
|
||||
'createContextCommits',
|
||||
'fetchContextCommits',
|
||||
'removeContextCommits',
|
||||
'setSelectedCommits',
|
||||
'setSearchText',
|
||||
'setToRemoveCommits',
|
||||
'resetModalState',
|
||||
]),
|
||||
focusSearch() {
|
||||
this.$refs.searchInput.focusInput();
|
||||
},
|
||||
openModal() {
|
||||
this.searchCommits();
|
||||
this.fetchContextCommits();
|
||||
this.$root.$emit('bv::show::modal', 'add-review-item');
|
||||
},
|
||||
handleTabChange(tabIndex) {
|
||||
if (tabIndex === 0) {
|
||||
this.focusSearch();
|
||||
if (this.shouldPurge) {
|
||||
this.setSelectedCommits(
|
||||
[...this.commits, ...this.selectedCommits].filter(commit => commit.isSelected),
|
||||
);
|
||||
}
|
||||
}
|
||||
},
|
||||
handleSearchCommits(value) {
|
||||
// We only call the service, if we have 3 characters or we don't have any characters
|
||||
if (value.length >= 3) {
|
||||
clearTimeout(this.timeout);
|
||||
this.timeout = setTimeout(() => {
|
||||
this.searchCommits(value);
|
||||
}, 500);
|
||||
} else if (value.length === 0) {
|
||||
this.searchCommits();
|
||||
}
|
||||
this.setSearchText(value);
|
||||
},
|
||||
handleCommitRowSelect(event) {
|
||||
const index = event[0];
|
||||
const selected = event[1];
|
||||
const tempCommit = this.tabIndex === 0 ? this.commits[index] : this.selectedCommits[index];
|
||||
const commitIndex = findCommitIndex(this.commits, tempCommit.short_id);
|
||||
const tempCommits = setCommitStatus(this.commits, commitIndex, selected);
|
||||
const selectedCommitIndex = findCommitIndex(this.selectedCommits, tempCommit.short_id);
|
||||
let tempSelectedCommits = setCommitStatus(
|
||||
this.selectedCommits,
|
||||
selectedCommitIndex,
|
||||
selected,
|
||||
);
|
||||
|
||||
if (selected) {
|
||||
// If user deselects a commit which is already present in previously merged commits, then user adds it again.
|
||||
// Then the state is neutral, so we remove it from the list
|
||||
this.setToRemoveCommits(
|
||||
removeIfReadyToBeRemoved(this.toRemoveCommits, tempCommit.short_id),
|
||||
);
|
||||
} else {
|
||||
// If user is present in first tab and deselects a commit, remove it directly
|
||||
if (this.tabIndex === 0) {
|
||||
tempSelectedCommits = removeIfPresent(tempSelectedCommits, tempCommit.short_id);
|
||||
}
|
||||
|
||||
// If user deselects a commit which is already present in previously merged commits, we keep track of it in a list to remove
|
||||
const contextCommitsIndex = findCommitIndex(this.contextCommits, tempCommit.short_id);
|
||||
if (contextCommitsIndex !== -1) {
|
||||
this.setToRemoveCommits([...this.toRemoveCommits, tempCommit.short_id]);
|
||||
}
|
||||
}
|
||||
|
||||
this.setCommits({ commits: tempCommits });
|
||||
this.setSelectedCommits([
|
||||
...tempSelectedCommits,
|
||||
...tempCommits.filter(commit => commit.isSelected),
|
||||
]);
|
||||
},
|
||||
handleCreateContextCommits() {
|
||||
if (this.uniqueCommits.length > 0 && this.toRemoveCommits.length > 0) {
|
||||
return Promise.all([
|
||||
this.createContextCommits({ commits: this.uniqueCommits }),
|
||||
this.removeContextCommits(),
|
||||
]).then(values => {
|
||||
if (values[0] || values[1]) {
|
||||
window.location.reload();
|
||||
}
|
||||
if (!values[0] && !values[1]) {
|
||||
createFlash(
|
||||
s__('ContextCommits|Failed to create/remove context commits. Please try again.'),
|
||||
);
|
||||
}
|
||||
});
|
||||
} else if (this.uniqueCommits.length > 0) {
|
||||
return this.createContextCommits({ commits: this.uniqueCommits, forceReload: true });
|
||||
}
|
||||
|
||||
return this.removeContextCommits(true);
|
||||
},
|
||||
handleModalClose() {
|
||||
this.resetModalState();
|
||||
clearTimeout(this.timeout);
|
||||
},
|
||||
handleModalHide() {
|
||||
this.resetModalState();
|
||||
clearTimeout(this.timeout);
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<gl-modal
|
||||
ref="modal"
|
||||
cancel-variant="light"
|
||||
size="md"
|
||||
body-class="add-review-item pt-0"
|
||||
:scrollable="true"
|
||||
:ok-title="__('Save changes')"
|
||||
modal-id="add-review-item"
|
||||
:title="__('Add or remove previously merged commits')"
|
||||
:ok-disabled="disableSaveButton"
|
||||
@shown="focusSearch"
|
||||
@ok="handleCreateContextCommits"
|
||||
@cancel="handleModalClose"
|
||||
@close="handleModalClose"
|
||||
@hide="handleModalHide"
|
||||
>
|
||||
<gl-tabs v-model="currentTabIndex" content-class="pt-0">
|
||||
<gl-tab>
|
||||
<template #title>
|
||||
<gl-sprintf :message="__(`Commits in %{codeStart}${targetBranch}%{codeEnd}`)">
|
||||
<template #code="{ content }">
|
||||
<code>{{ content }}</code>
|
||||
</template>
|
||||
</gl-sprintf>
|
||||
</template>
|
||||
<div class="mt-2">
|
||||
<gl-search-box-by-type
|
||||
ref="searchInput"
|
||||
:placeholder="__(`Search by commit title or SHA`)"
|
||||
@input="handleSearchCommits"
|
||||
/>
|
||||
<review-tab-container
|
||||
:is-loading="isLoadingCommits"
|
||||
:loading-error="commitsLoadingError"
|
||||
:loading-failed-text="__('Unable to load commits. Try again later.')"
|
||||
:commits="commits"
|
||||
:empty-list-text="__('Your search didn\'t match any commits. Try a different query.')"
|
||||
@handleCommitSelect="handleCommitRowSelect"
|
||||
/>
|
||||
</div>
|
||||
</gl-tab>
|
||||
<gl-tab>
|
||||
<template #title>
|
||||
{{ __('Selected commits') }}
|
||||
<span class="badge badge-pill">{{ selectedCommitsCount }}</span>
|
||||
</template>
|
||||
<review-tab-container
|
||||
:is-loading="isLoadingContextCommits"
|
||||
:loading-error="contextCommitsLoadingError"
|
||||
:loading-failed-text="__('Unable to load commits. Try again later.')"
|
||||
:commits="selectedCommits"
|
||||
:empty-list-text="
|
||||
__(
|
||||
'Commits you select appear here. Go to the first tab and select commits to add to this merge request.',
|
||||
)
|
||||
"
|
||||
@handleCommitSelect="handleCommitRowSelect"
|
||||
/>
|
||||
</gl-tab>
|
||||
</gl-tabs>
|
||||
</gl-modal>
|
||||
</template>
|
|
@ -0,0 +1,57 @@
|
|||
<script>
|
||||
import { GlLoadingIcon, GlAlert } from '@gitlab/ui';
|
||||
import CommitItem from '~/diffs/components/commit_item.vue';
|
||||
import { __ } from '~/locale';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlLoadingIcon,
|
||||
GlAlert,
|
||||
CommitItem,
|
||||
},
|
||||
props: {
|
||||
isLoading: {
|
||||
type: Boolean,
|
||||
required: true,
|
||||
},
|
||||
loadingError: {
|
||||
type: Boolean,
|
||||
required: true,
|
||||
},
|
||||
loadingFailedText: {
|
||||
type: String,
|
||||
required: true,
|
||||
},
|
||||
commits: {
|
||||
type: Array,
|
||||
required: true,
|
||||
},
|
||||
emptyListText: {
|
||||
type: String,
|
||||
required: false,
|
||||
default: __('No commits present here'),
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
<template>
|
||||
<gl-loading-icon v-if="isLoading" size="lg" class="mt-3" />
|
||||
<gl-alert v-else-if="loadingError" variant="danger" :dismissible="false" class="mt-3">
|
||||
{{ loadingFailedText }}
|
||||
</gl-alert>
|
||||
<div v-else-if="commits.length === 0" class="text-center mt-4">
|
||||
<span>{{ emptyListText }}</span>
|
||||
</div>
|
||||
<div v-else>
|
||||
<ul class="content-list commit-list flex-list">
|
||||
<commit-item
|
||||
v-for="(commit, index) in commits"
|
||||
:key="commit.id"
|
||||
:is-selectable="true"
|
||||
:commit="commit"
|
||||
:checked="commit.isSelected"
|
||||
@handleCheckboxChange="$emit('handleCommitSelect', [index, $event])"
|
||||
/>
|
||||
</ul>
|
||||
</div>
|
||||
</template>
|
64
app/assets/javascripts/add_context_commits_modal/index.js
Normal file
64
app/assets/javascripts/add_context_commits_modal/index.js
Normal file
|
@ -0,0 +1,64 @@
|
|||
import Vue from 'vue';
|
||||
import { parseBoolean } from '~/lib/utils/common_utils';
|
||||
import createStore from './store';
|
||||
import AddContextCommitsModalTrigger from './components/add_context_commits_modal_trigger.vue';
|
||||
import AddContextCommitsModalWrapper from './components/add_context_commits_modal_wrapper.vue';
|
||||
|
||||
export default function initAddContextCommitsTriggers() {
|
||||
const addContextCommitsModalTriggerEl = document.querySelector('.add-review-item-modal-trigger');
|
||||
const addContextCommitsModalWrapperEl = document.querySelector('.add-review-item-modal-wrapper');
|
||||
|
||||
if (addContextCommitsModalTriggerEl || addContextCommitsModalWrapperEl) {
|
||||
// eslint-disable-next-line no-new
|
||||
new Vue({
|
||||
el: addContextCommitsModalTriggerEl,
|
||||
data() {
|
||||
const { commitsEmpty, contextCommitsEmpty } = this.$options.el.dataset;
|
||||
return {
|
||||
commitsEmpty: parseBoolean(commitsEmpty),
|
||||
contextCommitsEmpty: parseBoolean(contextCommitsEmpty),
|
||||
};
|
||||
},
|
||||
render(createElement) {
|
||||
return createElement(AddContextCommitsModalTrigger, {
|
||||
props: {
|
||||
commitsEmpty: this.commitsEmpty,
|
||||
contextCommitsEmpty: this.contextCommitsEmpty,
|
||||
},
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
const store = createStore();
|
||||
|
||||
// eslint-disable-next-line no-new
|
||||
new Vue({
|
||||
el: addContextCommitsModalWrapperEl,
|
||||
store,
|
||||
data() {
|
||||
const {
|
||||
contextCommitsPath,
|
||||
targetBranch,
|
||||
mergeRequestIid,
|
||||
projectId,
|
||||
} = this.$options.el.dataset;
|
||||
return {
|
||||
contextCommitsPath,
|
||||
targetBranch,
|
||||
mergeRequestIid: Number(mergeRequestIid),
|
||||
projectId: Number(projectId),
|
||||
};
|
||||
},
|
||||
render(createElement) {
|
||||
return createElement(AddContextCommitsModalWrapper, {
|
||||
props: {
|
||||
contextCommitsPath: this.contextCommitsPath,
|
||||
targetBranch: this.targetBranch,
|
||||
mergeRequestIid: this.mergeRequestIid,
|
||||
projectId: this.projectId,
|
||||
},
|
||||
});
|
||||
},
|
||||
});
|
||||
}
|
||||
}
|
|
@ -0,0 +1,134 @@
|
|||
import _ from 'lodash';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
import { s__ } from '~/locale';
|
||||
import Api from '~/api';
|
||||
import * as types from './mutation_types';
|
||||
|
||||
export const setBaseConfig = ({ commit }, options) => {
|
||||
commit(types.SET_BASE_CONFIG, options);
|
||||
};
|
||||
|
||||
export const setTabIndex = ({ commit }, tabIndex) => commit(types.SET_TABINDEX, tabIndex);
|
||||
|
||||
export const searchCommits = ({ dispatch, commit, state }, searchText) => {
|
||||
commit(types.FETCH_COMMITS);
|
||||
|
||||
let params = {};
|
||||
if (searchText) {
|
||||
params = {
|
||||
params: {
|
||||
search: searchText,
|
||||
per_page: 40,
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
return axios
|
||||
.get(state.contextCommitsPath, params)
|
||||
.then(({ data }) => {
|
||||
let commits = data.map(o => ({ ...o, isSelected: false }));
|
||||
commits = commits.map(c => {
|
||||
const isPresent = state.selectedCommits.find(
|
||||
selectedCommit => selectedCommit.short_id === c.short_id && selectedCommit.isSelected,
|
||||
);
|
||||
if (isPresent) {
|
||||
return { ...c, isSelected: true };
|
||||
}
|
||||
return c;
|
||||
});
|
||||
if (!searchText) {
|
||||
dispatch('setCommits', { commits: [...commits, ...state.contextCommits] });
|
||||
} else {
|
||||
dispatch('setCommits', { commits });
|
||||
}
|
||||
})
|
||||
.catch(() => {
|
||||
commit(types.FETCH_COMMITS_ERROR);
|
||||
});
|
||||
};
|
||||
|
||||
export const setCommits = ({ commit }, { commits: data, silentAddition = false }) => {
|
||||
let commits = _.uniqBy(data, 'short_id');
|
||||
commits = _.orderBy(data, c => new Date(c.committed_date), ['desc']);
|
||||
if (silentAddition) {
|
||||
commit(types.SET_COMMITS_SILENT, commits);
|
||||
} else {
|
||||
commit(types.SET_COMMITS, commits);
|
||||
}
|
||||
};
|
||||
|
||||
export const createContextCommits = ({ state }, { commits, forceReload = false }) =>
|
||||
Api.createContextCommits(state.projectId, state.mergeRequestIid, {
|
||||
commits: commits.map(commit => commit.short_id),
|
||||
})
|
||||
.then(() => {
|
||||
if (forceReload) {
|
||||
window.location.reload();
|
||||
}
|
||||
|
||||
return true;
|
||||
})
|
||||
.catch(() => {
|
||||
if (forceReload) {
|
||||
createFlash(s__('ContextCommits|Failed to create context commits. Please try again.'));
|
||||
}
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
export const fetchContextCommits = ({ dispatch, commit, state }) => {
|
||||
commit(types.FETCH_CONTEXT_COMMITS);
|
||||
return Api.allContextCommits(state.projectId, state.mergeRequestIid)
|
||||
.then(({ data }) => {
|
||||
const contextCommits = data.map(o => ({ ...o, isSelected: true }));
|
||||
dispatch('setContextCommits', contextCommits);
|
||||
dispatch('setCommits', {
|
||||
commits: [...state.commits, ...contextCommits],
|
||||
silentAddition: true,
|
||||
});
|
||||
dispatch('setSelectedCommits', contextCommits);
|
||||
})
|
||||
.catch(() => {
|
||||
commit(types.FETCH_CONTEXT_COMMITS_ERROR);
|
||||
});
|
||||
};
|
||||
|
||||
export const setContextCommits = ({ commit }, data) => {
|
||||
commit(types.SET_CONTEXT_COMMITS, data);
|
||||
};
|
||||
|
||||
export const removeContextCommits = ({ state }, forceReload = false) =>
|
||||
Api.removeContextCommits(state.projectId, state.mergeRequestIid, {
|
||||
commits: state.toRemoveCommits,
|
||||
})
|
||||
.then(() => {
|
||||
if (forceReload) {
|
||||
window.location.reload();
|
||||
}
|
||||
|
||||
return true;
|
||||
})
|
||||
.catch(() => {
|
||||
if (forceReload) {
|
||||
createFlash(s__('ContextCommits|Failed to delete context commits. Please try again.'));
|
||||
}
|
||||
|
||||
return false;
|
||||
});
|
||||
|
||||
export const setSelectedCommits = ({ commit }, selected) => {
|
||||
let selectedCommits = _.uniqBy(selected, 'short_id');
|
||||
selectedCommits = _.orderBy(
|
||||
selectedCommits,
|
||||
selectedCommit => new Date(selectedCommit.committed_date),
|
||||
['desc'],
|
||||
);
|
||||
commit(types.SET_SELECTED_COMMITS, selectedCommits);
|
||||
};
|
||||
|
||||
export const setSearchText = ({ commit }, searchText) => commit(types.SET_SEARCH_TEXT, searchText);
|
||||
|
||||
export const setToRemoveCommits = ({ commit }, data) => commit(types.SET_TO_REMOVE_COMMITS, data);
|
||||
|
||||
export const resetModalState = ({ commit }) => commit(types.RESET_MODAL_STATE);
|
|
@ -0,0 +1,15 @@
|
|||
import Vue from 'vue';
|
||||
import Vuex from 'vuex';
|
||||
import * as actions from './actions';
|
||||
import mutations from './mutations';
|
||||
import state from './state';
|
||||
|
||||
Vue.use(Vuex);
|
||||
|
||||
export default () =>
|
||||
new Vuex.Store({
|
||||
namespaced: true,
|
||||
state: state(),
|
||||
actions,
|
||||
mutations,
|
||||
});
|
|
@ -0,0 +1,20 @@
|
|||
export const SET_BASE_CONFIG = 'SET_BASE_CONFIG';
|
||||
|
||||
export const SET_TABINDEX = 'SET_TABINDEX';
|
||||
|
||||
export const FETCH_COMMITS = 'FETCH_COMMITS';
|
||||
export const SET_COMMITS = 'SET_COMMITS';
|
||||
export const SET_COMMITS_SILENT = 'SET_COMMITS_SILENT';
|
||||
export const FETCH_COMMITS_ERROR = 'FETCH_COMMITS_ERROR';
|
||||
|
||||
export const FETCH_CONTEXT_COMMITS = 'FETCH_CONTEXT_COMMITS';
|
||||
export const SET_CONTEXT_COMMITS = 'SET_CONTEXT_COMMITS';
|
||||
export const FETCH_CONTEXT_COMMITS_ERROR = 'FETCH_CONTEXT_COMMITS_ERROR';
|
||||
|
||||
export const SET_SELECTED_COMMITS = 'SET_SELECTED_COMMITS';
|
||||
|
||||
export const SET_SEARCH_TEXT = 'SET_SEARCH_TEXT';
|
||||
|
||||
export const SET_TO_REMOVE_COMMITS = 'SET_TO_REMOVE_COMMITS';
|
||||
|
||||
export const RESET_MODAL_STATE = 'RESET_MODAL_STATE';
|
|
@ -0,0 +1,56 @@
|
|||
import * as types from './mutation_types';
|
||||
|
||||
export default {
|
||||
[types.SET_BASE_CONFIG](state, options) {
|
||||
Object.assign(state, { ...options });
|
||||
},
|
||||
[types.SET_TABINDEX](state, tabIndex) {
|
||||
state.tabIndex = tabIndex;
|
||||
},
|
||||
[types.FETCH_COMMITS](state) {
|
||||
state.isLoadingCommits = true;
|
||||
state.commitsLoadingError = false;
|
||||
},
|
||||
[types.SET_COMMITS](state, commits) {
|
||||
state.commits = commits;
|
||||
state.isLoadingCommits = false;
|
||||
state.commitsLoadingError = false;
|
||||
},
|
||||
[types.SET_COMMITS_SILENT](state, commits) {
|
||||
state.commits = commits;
|
||||
},
|
||||
[types.FETCH_COMMITS_ERROR](state) {
|
||||
state.commitsLoadingError = true;
|
||||
state.isLoadingCommits = false;
|
||||
},
|
||||
[types.FETCH_CONTEXT_COMMITS](state) {
|
||||
state.isLoadingContextCommits = true;
|
||||
state.contextCommitsLoadingError = false;
|
||||
},
|
||||
[types.SET_CONTEXT_COMMITS](state, contextCommits) {
|
||||
state.contextCommits = contextCommits;
|
||||
state.isLoadingContextCommits = false;
|
||||
state.contextCommitsLoadingError = false;
|
||||
},
|
||||
[types.FETCH_CONTEXT_COMMITS_ERROR](state) {
|
||||
state.contextCommitsLoadingError = true;
|
||||
state.isLoadingContextCommits = false;
|
||||
},
|
||||
[types.SET_SELECTED_COMMITS](state, commits) {
|
||||
state.selectedCommits = commits;
|
||||
},
|
||||
[types.SET_SEARCH_TEXT](state, searchText) {
|
||||
state.searchText = searchText;
|
||||
},
|
||||
[types.SET_TO_REMOVE_COMMITS](state, commits) {
|
||||
state.toRemoveCommits = commits;
|
||||
},
|
||||
[types.RESET_MODAL_STATE](state) {
|
||||
state.tabIndex = 0;
|
||||
state.commits = [];
|
||||
state.contextCommits = [];
|
||||
state.selectedCommits = [];
|
||||
state.toRemoveCommits = [];
|
||||
state.searchText = '';
|
||||
},
|
||||
};
|
|
@ -0,0 +1,13 @@
|
|||
export default () => ({
|
||||
contextCommitsPath: '',
|
||||
tabIndex: 0,
|
||||
isLoadingCommits: false,
|
||||
commits: [],
|
||||
commitsLoadingError: false,
|
||||
selectedCommits: [],
|
||||
isLoadingContextCommits: false,
|
||||
contextCommits: [],
|
||||
contextCommitsLoadingError: false,
|
||||
searchText: '',
|
||||
toRemoveCommits: [],
|
||||
});
|
32
app/assets/javascripts/add_context_commits_modal/utils.js
Normal file
32
app/assets/javascripts/add_context_commits_modal/utils.js
Normal file
|
@ -0,0 +1,32 @@
|
|||
export const findCommitIndex = (commits, commitShortId) => {
|
||||
return commits.findIndex(commit => commit.short_id === commitShortId);
|
||||
};
|
||||
|
||||
export const setCommitStatus = (commits, commitIndex, selected) => {
|
||||
const tempCommits = [...commits];
|
||||
tempCommits[commitIndex] = {
|
||||
...tempCommits[commitIndex],
|
||||
isSelected: selected,
|
||||
};
|
||||
return tempCommits;
|
||||
};
|
||||
|
||||
export const removeIfReadyToBeRemoved = (toRemoveCommits, commitShortId) => {
|
||||
const tempToRemoveCommits = [...toRemoveCommits];
|
||||
const isPresentInToRemove = tempToRemoveCommits.indexOf(commitShortId);
|
||||
if (isPresentInToRemove !== -1) {
|
||||
tempToRemoveCommits.splice(isPresentInToRemove, 1);
|
||||
}
|
||||
|
||||
return tempToRemoveCommits;
|
||||
};
|
||||
|
||||
export const removeIfPresent = (selectedCommits, commitShortId) => {
|
||||
const tempSelectedCommits = [...selectedCommits];
|
||||
const selectedCommitsIndex = findCommitIndex(tempSelectedCommits, commitShortId);
|
||||
if (selectedCommitsIndex !== -1) {
|
||||
tempSelectedCommits.splice(selectedCommitsIndex, 1);
|
||||
}
|
||||
|
||||
return tempSelectedCommits;
|
||||
};
|
|
@ -1,6 +1,6 @@
|
|||
import Api from '~/api';
|
||||
import { s__ } from '~/locale';
|
||||
import createFlash from '~/flash';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
import { convertObjectPropsToCamelCase } from '~/lib/utils/common_utils';
|
||||
import * as types from './mutation_types';
|
||||
|
||||
|
@ -23,6 +23,3 @@ export const receiveStatisticsError = ({ commit }, error) => {
|
|||
commit(types.RECEIVE_STATISTICS_ERROR, error);
|
||||
createFlash(s__('AdminDashboard|Error loading the statistics. Please try again'));
|
||||
};
|
||||
|
||||
// prevent babel-plugin-rewire from generating an invalid default during karma tests
|
||||
export default () => {};
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
* and returns an array of the following form:
|
||||
* [{ key: "forks", label: "Forks", value: 50 }]
|
||||
*/
|
||||
// eslint-disable-next-line import/prefer-default-export
|
||||
export const getStatistics = state => labels =>
|
||||
Object.keys(labels).map(key => {
|
||||
const result = {
|
||||
|
@ -12,6 +13,3 @@ export const getStatistics = state => labels =>
|
|||
};
|
||||
return result;
|
||||
});
|
||||
|
||||
// prevent babel-plugin-rewire from generating an invalid default during karma tests
|
||||
export default () => {};
|
||||
|
|
|
@ -35,13 +35,24 @@ export default {
|
|||
errorMsg: s__(
|
||||
'AlertManagement|There was an error displaying the alert. Please refresh the page to try again.',
|
||||
),
|
||||
fullAlertDetailsTitle: s__('AlertManagement|Alert details'),
|
||||
overviewTitle: s__('AlertManagement|Overview'),
|
||||
metricsTitle: s__('AlertManagement|Metrics'),
|
||||
reportedAt: s__('AlertManagement|Reported %{when}'),
|
||||
reportedAtWithTool: s__('AlertManagement|Reported %{when} by %{tool}'),
|
||||
},
|
||||
severityLabels: ALERTS_SEVERITY_LABELS,
|
||||
tabsConfig: [
|
||||
{
|
||||
id: 'overview',
|
||||
title: s__('AlertManagement|Overview'),
|
||||
},
|
||||
{
|
||||
id: 'fullDetails',
|
||||
title: s__('AlertManagement|Alert details'),
|
||||
},
|
||||
{
|
||||
id: 'metrics',
|
||||
title: s__('AlertManagement|Metrics'),
|
||||
},
|
||||
],
|
||||
components: {
|
||||
GlBadge,
|
||||
GlAlert,
|
||||
|
@ -102,8 +113,8 @@ export default {
|
|||
errored: false,
|
||||
sidebarStatus: false,
|
||||
isErrorDismissed: false,
|
||||
createIssueError: '',
|
||||
issueCreationInProgress: false,
|
||||
createIncidentError: '',
|
||||
incidentCreationInProgress: false,
|
||||
sidebarErrorMessage: '',
|
||||
};
|
||||
},
|
||||
|
@ -119,6 +130,18 @@ export default {
|
|||
showErrorMsg() {
|
||||
return this.errored && !this.isErrorDismissed;
|
||||
},
|
||||
activeTab() {
|
||||
return this.$route.params.tabId || this.$options.tabsConfig[0].id;
|
||||
},
|
||||
currentTabIndex: {
|
||||
get() {
|
||||
return this.$options.tabsConfig.findIndex(tab => tab.id === this.activeTab);
|
||||
},
|
||||
set(tabIdx) {
|
||||
const tabId = this.$options.tabsConfig[tabIdx].id;
|
||||
this.$router.replace({ name: 'tab', params: { tabId } });
|
||||
},
|
||||
},
|
||||
},
|
||||
mounted() {
|
||||
this.trackPageViews();
|
||||
|
@ -149,8 +172,8 @@ export default {
|
|||
this.errored = true;
|
||||
this.sidebarErrorMessage = errorMessage;
|
||||
},
|
||||
createIssue() {
|
||||
this.issueCreationInProgress = true;
|
||||
createIncident() {
|
||||
this.incidentCreationInProgress = true;
|
||||
|
||||
this.$apollo
|
||||
.mutate({
|
||||
|
@ -162,18 +185,18 @@ export default {
|
|||
})
|
||||
.then(({ data: { createAlertIssue: { errors, issue } } }) => {
|
||||
if (errors?.length) {
|
||||
[this.createIssueError] = errors;
|
||||
this.issueCreationInProgress = false;
|
||||
[this.createIncidentError] = errors;
|
||||
this.incidentCreationInProgress = false;
|
||||
} else if (issue) {
|
||||
visitUrl(this.issuePath(issue.iid));
|
||||
visitUrl(this.incidentPath(issue.iid));
|
||||
}
|
||||
})
|
||||
.catch(error => {
|
||||
this.createIssueError = error;
|
||||
this.issueCreationInProgress = false;
|
||||
this.createIncidentError = error;
|
||||
this.incidentCreationInProgress = false;
|
||||
});
|
||||
},
|
||||
issuePath(issueId) {
|
||||
incidentPath(issueId) {
|
||||
return joinPaths(this.projectIssuesPath, issueId);
|
||||
},
|
||||
trackPageViews() {
|
||||
|
@ -190,12 +213,12 @@ export default {
|
|||
<p v-html="sidebarErrorMessage || $options.i18n.errorMsg"></p>
|
||||
</gl-alert>
|
||||
<gl-alert
|
||||
v-if="createIssueError"
|
||||
v-if="createIncidentError"
|
||||
variant="danger"
|
||||
data-testid="issueCreationError"
|
||||
@dismiss="createIssueError = null"
|
||||
data-testid="incidentCreationError"
|
||||
@dismiss="createIncidentError = null"
|
||||
>
|
||||
{{ createIssueError }}
|
||||
{{ createIncidentError }}
|
||||
</gl-alert>
|
||||
<div v-if="loading"><gl-loading-icon size="lg" class="gl-mt-5" /></div>
|
||||
<div
|
||||
|
@ -204,19 +227,12 @@ export default {
|
|||
:class="{ 'pr-sm-8': sidebarStatus }"
|
||||
>
|
||||
<div
|
||||
class="gl-display-flex gl-justify-content-space-between gl-align-items-baseline gl-px-1 py-3 py-md-4 gl-border-b-1 gl-border-b-gray-100 gl-border-b-solid flex-column flex-sm-row"
|
||||
>
|
||||
<div
|
||||
data-testid="alert-header"
|
||||
class="gl-display-flex gl-align-items-center gl-justify-content-center"
|
||||
>
|
||||
<div
|
||||
class="gl-display-inline-flex gl-align-items-center gl-justify-content-space-between"
|
||||
class="gl-display-flex gl-justify-content-space-between gl-align-items-center gl-px-1 py-3 py-md-4 gl-border-b-1 gl-border-b-gray-100 gl-border-b-solid gl-flex-direction-column gl-sm-flex-direction-row"
|
||||
>
|
||||
<div data-testid="alert-header">
|
||||
<gl-badge class="gl-mr-3">
|
||||
<strong>{{ s__('AlertManagement|Alert') }}</strong>
|
||||
</gl-badge>
|
||||
</div>
|
||||
<span>
|
||||
<gl-sprintf :message="reportedAtMessage">
|
||||
<template #when>
|
||||
|
@ -228,24 +244,24 @@ export default {
|
|||
</div>
|
||||
<gl-button
|
||||
v-if="alert.issueIid"
|
||||
class="gl-mt-3 mt-sm-0 align-self-center align-self-sm-baseline alert-details-issue-button"
|
||||
data-testid="viewIssueBtn"
|
||||
:href="issuePath(alert.issueIid)"
|
||||
class="gl-mt-3 mt-sm-0 align-self-center align-self-sm-baseline alert-details-incident-button"
|
||||
data-testid="viewIncidentBtn"
|
||||
:href="incidentPath(alert.issueIid)"
|
||||
category="primary"
|
||||
variant="success"
|
||||
>
|
||||
{{ s__('AlertManagement|View issue') }}
|
||||
{{ s__('AlertManagement|View incident') }}
|
||||
</gl-button>
|
||||
<gl-button
|
||||
v-else
|
||||
class="gl-mt-3 mt-sm-0 align-self-center align-self-sm-baseline alert-details-issue-button"
|
||||
data-testid="createIssueBtn"
|
||||
:loading="issueCreationInProgress"
|
||||
class="gl-mt-3 mt-sm-0 align-self-center align-self-sm-baseline alert-details-incident-button"
|
||||
data-testid="createIncidentBtn"
|
||||
:loading="incidentCreationInProgress"
|
||||
category="primary"
|
||||
variant="success"
|
||||
@click="createIssue()"
|
||||
@click="createIncident()"
|
||||
>
|
||||
{{ s__('AlertManagement|Create issue') }}
|
||||
{{ s__('AlertManagement|Create incident') }}
|
||||
</gl-button>
|
||||
<gl-button
|
||||
:aria-label="__('Toggle sidebar')"
|
||||
|
@ -264,8 +280,8 @@ export default {
|
|||
>
|
||||
<h2 data-testid="title">{{ alert.title }}</h2>
|
||||
</div>
|
||||
<gl-tabs v-if="alert" data-testid="alertDetailsTabs">
|
||||
<gl-tab data-testid="overviewTab" :title="$options.i18n.overviewTitle">
|
||||
<gl-tabs v-if="alert" v-model="currentTabIndex" data-testid="alertDetailsTabs">
|
||||
<gl-tab :data-testid="$options.tabsConfig[0].id" :title="$options.tabsConfig[0].title">
|
||||
<div v-if="alert.severity" class="gl-mt-3 gl-mb-5 gl-display-flex">
|
||||
<div class="gl-font-weight-bold gl-w-13 gl-text-right gl-pr-3">
|
||||
{{ s__('AlertManagement|Severity') }}:
|
||||
|
@ -308,6 +324,12 @@ export default {
|
|||
</div>
|
||||
<div class="gl-pl-2" data-testid="service">{{ alert.service }}</div>
|
||||
</div>
|
||||
<div v-if="alert.runbook" class="gl-my-5 gl-display-flex">
|
||||
<div class="bold gl-w-13 gl-text-right gl-pr-3">
|
||||
{{ s__('AlertManagement|Runbook') }}:
|
||||
</div>
|
||||
<div class="gl-pl-2" data-testid="runbook">{{ alert.runbook }}</div>
|
||||
</div>
|
||||
<template>
|
||||
<div v-if="alert.notes.nodes" class="issuable-discussion py-5">
|
||||
<ul class="notes main-notes-list timeline">
|
||||
|
@ -316,7 +338,7 @@ export default {
|
|||
</div>
|
||||
</template>
|
||||
</gl-tab>
|
||||
<gl-tab data-testid="fullDetailsTab" :title="$options.i18n.fullAlertDetailsTitle">
|
||||
<gl-tab :data-testid="$options.tabsConfig[1].id" :title="$options.tabsConfig[1].title">
|
||||
<gl-table
|
||||
class="alert-management-details-table"
|
||||
:items="[{ key: 'Value', ...alert }]"
|
||||
|
@ -332,7 +354,7 @@ export default {
|
|||
</template>
|
||||
</gl-table>
|
||||
</gl-tab>
|
||||
<gl-tab data-testId="metricsTab" :title="$options.i18n.metricsTitle">
|
||||
<gl-tab :data-testid="$options.tabsConfig[2].id" :title="$options.tabsConfig[2].title">
|
||||
<alert-metrics :dashboard-url="alert.metricsDashboardUrl" />
|
||||
</gl-tab>
|
||||
</gl-tabs>
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
<script>
|
||||
import { GlEmptyState, GlButton } from '@gitlab/ui';
|
||||
import { GlEmptyState, GlButton, GlLink } from '@gitlab/ui';
|
||||
import { s__ } from '~/locale';
|
||||
import alertsHelpUrlQuery from '../graphql/queries/alert_help_url.query.graphql';
|
||||
|
||||
export default {
|
||||
i18n: {
|
||||
|
@ -25,6 +26,12 @@ export default {
|
|||
components: {
|
||||
GlEmptyState,
|
||||
GlButton,
|
||||
GlLink,
|
||||
},
|
||||
apollo: {
|
||||
alertsHelpUrl: {
|
||||
query: alertsHelpUrlQuery,
|
||||
},
|
||||
},
|
||||
props: {
|
||||
enableAlertManagementPath: {
|
||||
|
@ -50,6 +57,11 @@ export default {
|
|||
default: '',
|
||||
},
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
alertsHelpUrl: '',
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
emptyState() {
|
||||
return {
|
||||
|
@ -71,13 +83,9 @@ export default {
|
|||
<template #description>
|
||||
<div class="gl-display-block">
|
||||
<span>{{ emptyState.info }}</span>
|
||||
<a
|
||||
v-if="!opsgenieMvcEnabled"
|
||||
href="/help/user/project/operations/alert_management.html"
|
||||
target="_blank"
|
||||
>
|
||||
<gl-link v-if="!opsgenieMvcEnabled" :href="alertsHelpUrl" target="_blank">
|
||||
{{ $options.i18n.moreInformation }}
|
||||
</a>
|
||||
</gl-link>
|
||||
</div>
|
||||
<div v-if="alertsCanBeEnabled" class="gl-display-block center gl-pt-4">
|
||||
<gl-button category="primary" variant="success" :href="emptyState.link">
|
||||
|
|
|
@ -12,8 +12,8 @@ import {
|
|||
GlSearchBoxByType,
|
||||
GlSprintf,
|
||||
} from '@gitlab/ui';
|
||||
import { __, s__ } from '~/locale';
|
||||
import { debounce, trim } from 'lodash';
|
||||
import { __, s__ } from '~/locale';
|
||||
import { joinPaths, visitUrl } from '~/lib/utils/url_utility';
|
||||
import { fetchPolicies } from '~/lib/graphql';
|
||||
import TimeAgo from '~/vue_shared/components/time_ago_tooltip.vue';
|
||||
|
@ -60,15 +60,15 @@ export default {
|
|||
{
|
||||
key: 'severity',
|
||||
label: s__('AlertManagement|Severity'),
|
||||
tdClass: `${tdClass} rounded-top text-capitalize`,
|
||||
thClass: `${thClass} gl-w-eighth`,
|
||||
tdClass: `${tdClass} rounded-top text-capitalize sortable-cell`,
|
||||
sortable: true,
|
||||
},
|
||||
{
|
||||
key: 'startedAt',
|
||||
label: s__('AlertManagement|Start time'),
|
||||
thClass: `${thClass} js-started-at w-15p`,
|
||||
tdClass,
|
||||
tdClass: `${tdClass} sortable-cell`,
|
||||
sortable: true,
|
||||
},
|
||||
{
|
||||
|
@ -81,7 +81,7 @@ export default {
|
|||
key: 'eventCount',
|
||||
label: s__('AlertManagement|Events'),
|
||||
thClass: `${thClass} text-right gl-w-12`,
|
||||
tdClass: `${tdClass} text-md-right`,
|
||||
tdClass: `${tdClass} text-md-right sortable-cell`,
|
||||
sortable: true,
|
||||
},
|
||||
{
|
||||
|
@ -89,7 +89,6 @@ export default {
|
|||
label: s__('AlertManagement|Issue'),
|
||||
thClass: 'gl-w-12 gl-pointer-events-none',
|
||||
tdClass,
|
||||
sortable: false,
|
||||
},
|
||||
{
|
||||
key: 'assignees',
|
||||
|
@ -99,9 +98,9 @@ export default {
|
|||
},
|
||||
{
|
||||
key: 'status',
|
||||
thClass: `${thClass} w-15p`,
|
||||
label: s__('AlertManagement|Status'),
|
||||
tdClass: `${tdClass} rounded-bottom`,
|
||||
thClass: `${thClass} w-15p`,
|
||||
tdClass: `${tdClass} rounded-bottom sortable-cell`,
|
||||
sortable: true,
|
||||
},
|
||||
],
|
||||
|
@ -169,7 +168,7 @@ export default {
|
|||
};
|
||||
},
|
||||
error() {
|
||||
this.errored = true;
|
||||
this.hasError = true;
|
||||
},
|
||||
},
|
||||
alertsCount: {
|
||||
|
@ -188,10 +187,9 @@ export default {
|
|||
data() {
|
||||
return {
|
||||
searchTerm: '',
|
||||
errored: false,
|
||||
hasError: false,
|
||||
errorMessage: '',
|
||||
isAlertDismissed: false,
|
||||
isErrorAlertDismissed: false,
|
||||
sort: 'STARTED_AT_DESC',
|
||||
statusFilter: [],
|
||||
filteredByStatus: '',
|
||||
|
@ -204,16 +202,13 @@ export default {
|
|||
computed: {
|
||||
showNoAlertsMsg() {
|
||||
return (
|
||||
!this.errored &&
|
||||
!this.hasError &&
|
||||
!this.loading &&
|
||||
this.alertsCount?.all === 0 &&
|
||||
!this.searchTerm &&
|
||||
!this.isAlertDismissed
|
||||
);
|
||||
},
|
||||
showErrorMsg() {
|
||||
return this.errored && !this.isErrorAlertDismissed;
|
||||
},
|
||||
loading() {
|
||||
return this.$apollo.queries.alerts.loading;
|
||||
},
|
||||
|
@ -307,11 +302,11 @@ export default {
|
|||
};
|
||||
},
|
||||
handleAlertError(errorMessage) {
|
||||
this.errored = true;
|
||||
this.hasError = true;
|
||||
this.errorMessage = errorMessage;
|
||||
},
|
||||
dismissError() {
|
||||
this.isErrorAlertDismissed = true;
|
||||
this.hasError = false;
|
||||
this.errorMessage = '';
|
||||
},
|
||||
},
|
||||
|
@ -319,7 +314,7 @@ export default {
|
|||
</script>
|
||||
<template>
|
||||
<div>
|
||||
<div class="alert-management-list">
|
||||
<div class="incident-management-list">
|
||||
<gl-alert v-if="showNoAlertsMsg" @dismiss="isAlertDismissed = true">
|
||||
<gl-sprintf :message="$options.i18n.noAlertsMsg">
|
||||
<template #link="{ content }">
|
||||
|
@ -333,16 +328,14 @@ export default {
|
|||
</template>
|
||||
</gl-sprintf>
|
||||
</gl-alert>
|
||||
<gl-alert
|
||||
v-if="showErrorMsg"
|
||||
variant="danger"
|
||||
data-testid="alert-error"
|
||||
@dismiss="dismissError"
|
||||
>
|
||||
<gl-alert v-if="hasError" variant="danger" data-testid="alert-error" @dismiss="dismissError">
|
||||
<p v-html="errorMessage || $options.i18n.errorMsg"></p>
|
||||
</gl-alert>
|
||||
|
||||
<gl-tabs content-class="gl-p-0" @input="filterAlertsByStatus">
|
||||
<gl-tabs
|
||||
content-class="gl-p-0 gl-border-b-solid gl-border-b-1 gl-border-gray-100"
|
||||
@input="filterAlertsByStatus"
|
||||
>
|
||||
<gl-tab v-for="tab in $options.statusTabs" :key="tab.status">
|
||||
<template slot="title">
|
||||
<span>{{ tab.title }}</span>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<script>
|
||||
import { GlDropdown, GlDropdownItem, GlButton } from '@gitlab/ui';
|
||||
import { GlDeprecatedDropdown, GlDeprecatedDropdownItem, GlButton } from '@gitlab/ui';
|
||||
import { s__ } from '~/locale';
|
||||
import Tracking from '~/tracking';
|
||||
import { trackAlertStatusUpdateOptions } from '../constants';
|
||||
|
@ -18,8 +18,8 @@ export default {
|
|||
RESOLVED: s__('AlertManagement|Resolved'),
|
||||
},
|
||||
components: {
|
||||
GlDropdown,
|
||||
GlDropdownItem,
|
||||
GlDeprecatedDropdown,
|
||||
GlDeprecatedDropdownItem,
|
||||
GlButton,
|
||||
},
|
||||
props: {
|
||||
|
@ -91,7 +91,7 @@ export default {
|
|||
|
||||
<template>
|
||||
<div class="dropdown dropdown-menu-selectable" :class="dropdownClass">
|
||||
<gl-dropdown
|
||||
<gl-deprecated-dropdown
|
||||
ref="dropdown"
|
||||
right
|
||||
:text="$options.statuses[alert.status]"
|
||||
|
@ -112,7 +112,7 @@ export default {
|
|||
/>
|
||||
</div>
|
||||
<div class="dropdown-content dropdown-body">
|
||||
<gl-dropdown-item
|
||||
<gl-deprecated-dropdown-item
|
||||
v-for="(label, field) in $options.statuses"
|
||||
:key="field"
|
||||
data-testid="statusDropdownItem"
|
||||
|
@ -122,8 +122,8 @@ export default {
|
|||
@click="updateAlertStatus(label)"
|
||||
>
|
||||
{{ label }}
|
||||
</gl-dropdown-item>
|
||||
</gl-deprecated-dropdown-item>
|
||||
</div>
|
||||
</gl-dropdown>
|
||||
</gl-deprecated-dropdown>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<script>
|
||||
import { GlDropdownItem } from '@gitlab/ui';
|
||||
import { GlDeprecatedDropdownItem } from '@gitlab/ui';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlDropdownItem,
|
||||
GlDeprecatedDropdownItem,
|
||||
},
|
||||
props: {
|
||||
user: {
|
||||
|
@ -24,7 +24,7 @@ export default {
|
|||
</script>
|
||||
|
||||
<template>
|
||||
<gl-dropdown-item
|
||||
<gl-deprecated-dropdown-item
|
||||
:key="user.username"
|
||||
data-testid="assigneeDropdownItem"
|
||||
class="assignee-dropdown-item gl-vertical-align-middle"
|
||||
|
@ -47,5 +47,5 @@ export default {
|
|||
</strong>
|
||||
<span class="dropdown-menu-user-username"> {{ user.username }}</span>
|
||||
</span>
|
||||
</gl-dropdown-item>
|
||||
</gl-deprecated-dropdown-item>
|
||||
</template>
|
||||
|
|
|
@ -1,20 +1,20 @@
|
|||
<script>
|
||||
import {
|
||||
GlIcon,
|
||||
GlDropdown,
|
||||
GlDropdownDivider,
|
||||
GlDropdownHeader,
|
||||
GlDropdownItem,
|
||||
GlDeprecatedDropdown,
|
||||
GlDeprecatedDropdownDivider,
|
||||
GlDeprecatedDropdownHeader,
|
||||
GlDeprecatedDropdownItem,
|
||||
GlLoadingIcon,
|
||||
GlTooltip,
|
||||
GlButton,
|
||||
GlSprintf,
|
||||
} from '@gitlab/ui';
|
||||
import { debounce } from 'lodash';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import { s__, __ } from '~/locale';
|
||||
import alertSetAssignees from '../../graphql/mutations/alert_set_assignees.mutation.graphql';
|
||||
import SidebarAssignee from './sidebar_assignee.vue';
|
||||
import { debounce } from 'lodash';
|
||||
|
||||
const DATA_REFETCH_DELAY = 250;
|
||||
|
||||
|
@ -33,10 +33,10 @@ export default {
|
|||
},
|
||||
components: {
|
||||
GlIcon,
|
||||
GlDropdown,
|
||||
GlDropdownItem,
|
||||
GlDropdownDivider,
|
||||
GlDropdownHeader,
|
||||
GlDeprecatedDropdown,
|
||||
GlDeprecatedDropdownItem,
|
||||
GlDeprecatedDropdownDivider,
|
||||
GlDeprecatedDropdownHeader,
|
||||
GlLoadingIcon,
|
||||
GlTooltip,
|
||||
GlButton,
|
||||
|
@ -213,7 +213,7 @@ export default {
|
|||
</p>
|
||||
|
||||
<div class="dropdown dropdown-menu-selectable" :class="dropdownClass">
|
||||
<gl-dropdown
|
||||
<gl-deprecated-dropdown
|
||||
ref="dropdown"
|
||||
:text="assignedUser"
|
||||
class="w-100"
|
||||
|
@ -243,18 +243,18 @@ export default {
|
|||
</div>
|
||||
<div class="dropdown-content dropdown-body">
|
||||
<template v-if="userListValid">
|
||||
<gl-dropdown-item
|
||||
<gl-deprecated-dropdown-item
|
||||
:active="!userName"
|
||||
active-class="is-active"
|
||||
@click="updateAlertAssignees('')"
|
||||
>
|
||||
{{ __('Unassigned') }}
|
||||
</gl-dropdown-item>
|
||||
<gl-dropdown-divider />
|
||||
</gl-deprecated-dropdown-item>
|
||||
<gl-deprecated-dropdown-divider />
|
||||
|
||||
<gl-dropdown-header class="mt-0">
|
||||
<gl-deprecated-dropdown-header class="mt-0">
|
||||
{{ __('Assignee') }}
|
||||
</gl-dropdown-header>
|
||||
</gl-deprecated-dropdown-header>
|
||||
<sidebar-assignee
|
||||
v-for="user in sortedUsers"
|
||||
:key="user.username"
|
||||
|
@ -263,17 +263,17 @@ export default {
|
|||
@update-alert-assignees="updateAlertAssignees"
|
||||
/>
|
||||
</template>
|
||||
<gl-dropdown-item v-else-if="userListEmpty">
|
||||
<gl-deprecated-dropdown-item v-else-if="userListEmpty">
|
||||
{{ __('No Matching Results') }}
|
||||
</gl-dropdown-item>
|
||||
</gl-deprecated-dropdown-item>
|
||||
<gl-loading-icon v-else />
|
||||
</div>
|
||||
</gl-dropdown>
|
||||
</gl-deprecated-dropdown>
|
||||
</div>
|
||||
|
||||
<gl-loading-icon v-if="isUpdating" :inline="true" />
|
||||
<p v-else-if="!isDropdownShowing" class="value gl-m-0" :class="{ 'no-value': !userName }">
|
||||
<span v-if="userName" class="gl-text-gray-700" data-testid="assigned-users">{{
|
||||
<span v-if="userName" class="gl-text-gray-500" data-testid="assigned-users">{{
|
||||
assignedUser
|
||||
}}</span>
|
||||
<span v-else class="gl-display-flex gl-align-items-center">
|
||||
|
|
|
@ -27,7 +27,7 @@ export default {
|
|||
<template>
|
||||
<div class="block gl-display-flex gl-justify-content-space-between">
|
||||
<span class="issuable-header-text hide-collapsed">
|
||||
{{ __('To Do') }}
|
||||
{{ __('To-Do') }}
|
||||
</span>
|
||||
<sidebar-todo
|
||||
v-if="!sidebarCollapsed"
|
||||
|
|
|
@ -107,7 +107,7 @@ export default {
|
|||
>
|
||||
<span
|
||||
v-if="$options.statuses[alert.status]"
|
||||
class="gl-text-gray-700"
|
||||
class="gl-text-gray-500"
|
||||
data-testid="status"
|
||||
>{{ $options.statuses[alert.status] }}</span
|
||||
>
|
||||
|
|
|
@ -1,13 +1,14 @@
|
|||
<script>
|
||||
import { s__ } from '~/locale';
|
||||
import Todo from '~/sidebar/components/todo_toggle/todo.vue';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import createAlertTodo from '../../graphql/mutations/alert_todo_create.graphql';
|
||||
import createAlertTodo from '../../graphql/mutations/alert_todo_create.mutation.graphql';
|
||||
import todoMarkDone from '../../graphql/mutations/alert_todo_mark_done.mutation.graphql';
|
||||
import alertQuery from '../../graphql/queries/details.query.graphql';
|
||||
|
||||
export default {
|
||||
i18n: {
|
||||
UPDATE_ALERT_TODO_ERROR: s__(
|
||||
'AlertManagement|There was an error while updating the To Do of the alert.',
|
||||
'AlertManagement|There was an error while updating the To-Do of the alert.',
|
||||
),
|
||||
},
|
||||
components: {
|
||||
|
@ -30,14 +31,24 @@ export default {
|
|||
data() {
|
||||
return {
|
||||
isUpdating: false,
|
||||
isTodo: false,
|
||||
todo: '',
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
alertID() {
|
||||
return parseInt(this.alert.iid, 10);
|
||||
},
|
||||
firstToDoId() {
|
||||
return this.alert?.todos?.nodes[0]?.id;
|
||||
},
|
||||
hasPendingTodos() {
|
||||
return this.alert?.todos?.nodes.length > 0;
|
||||
},
|
||||
getAlertQueryVariables() {
|
||||
return {
|
||||
fullPath: this.projectPath,
|
||||
alertId: this.alert.iid,
|
||||
};
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
updateToDoCount(add) {
|
||||
|
@ -51,11 +62,7 @@ export default {
|
|||
|
||||
return document.dispatchEvent(headerTodoEvent);
|
||||
},
|
||||
toggleTodo() {
|
||||
if (this.todo) {
|
||||
return this.markAsDone();
|
||||
}
|
||||
|
||||
addToDo() {
|
||||
this.isUpdating = true;
|
||||
return this.$apollo
|
||||
.mutate({
|
||||
|
@ -65,24 +72,14 @@ export default {
|
|||
projectPath: this.projectPath,
|
||||
},
|
||||
})
|
||||
.then(({ data: { alertTodoCreate: { todo = {}, errors = [] } } = {} } = {}) => {
|
||||
.then(({ data: { errors = [] } }) => {
|
||||
if (errors[0]) {
|
||||
return this.$emit(
|
||||
'alert-error',
|
||||
`${this.$options.i18n.UPDATE_ALERT_TODO_ERROR} ${errors[0]}.`,
|
||||
);
|
||||
return this.throwError(errors[0]);
|
||||
}
|
||||
|
||||
this.todo = todo.id;
|
||||
return this.updateToDoCount(true);
|
||||
})
|
||||
.catch(() => {
|
||||
this.$emit(
|
||||
'alert-error',
|
||||
`${this.$options.i18n.UPDATE_ALERT_TODO_ERROR} ${s__(
|
||||
'AlertManagement|Please try again.',
|
||||
)}`,
|
||||
);
|
||||
this.throwError();
|
||||
})
|
||||
.finally(() => {
|
||||
this.isUpdating = false;
|
||||
|
@ -90,20 +87,45 @@ export default {
|
|||
},
|
||||
markAsDone() {
|
||||
this.isUpdating = true;
|
||||
|
||||
return axios
|
||||
.delete(`/dashboard/todos/${this.todo.split('/').pop()}`)
|
||||
.then(() => {
|
||||
this.todo = '';
|
||||
return this.$apollo
|
||||
.mutate({
|
||||
mutation: todoMarkDone,
|
||||
variables: {
|
||||
id: this.firstToDoId,
|
||||
},
|
||||
update: this.updateCache,
|
||||
})
|
||||
.then(({ data: { errors = [] } }) => {
|
||||
if (errors[0]) {
|
||||
return this.throwError(errors[0]);
|
||||
}
|
||||
return this.updateToDoCount(false);
|
||||
})
|
||||
.catch(() => {
|
||||
this.$emit('alert-error', this.$options.i18n.UPDATE_ALERT_TODO_ERROR);
|
||||
this.throwError();
|
||||
})
|
||||
.finally(() => {
|
||||
this.isUpdating = false;
|
||||
});
|
||||
},
|
||||
updateCache(store) {
|
||||
const data = store.readQuery({
|
||||
query: alertQuery,
|
||||
variables: this.getAlertQueryVariables,
|
||||
});
|
||||
|
||||
data.project.alertManagementAlerts.nodes[0].todos.nodes.shift();
|
||||
|
||||
store.writeQuery({
|
||||
query: alertQuery,
|
||||
variables: this.getAlertQueryVariables,
|
||||
data,
|
||||
});
|
||||
},
|
||||
throwError(err = '') {
|
||||
const error = err || s__('AlertManagement|Please try again.');
|
||||
this.$emit('alert-error', `${this.$options.i18n.UPDATE_ALERT_TODO_ERROR} ${error}`);
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
@ -114,10 +136,10 @@ export default {
|
|||
data-testid="alert-todo-button"
|
||||
:collapsed="sidebarCollapsed"
|
||||
:issuable-id="alertID"
|
||||
:is-todo="todo !== ''"
|
||||
:is-todo="hasPendingTodos"
|
||||
:is-action-active="isUpdating"
|
||||
issuable-type="alert"
|
||||
@toggleTodo="toggleTodo"
|
||||
@toggleTodo="hasPendingTodos ? markAsDone() : addToDo()"
|
||||
/>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -1,7 +1,8 @@
|
|||
import Vue from 'vue';
|
||||
import VueApollo from 'vue-apollo';
|
||||
import createDefaultClient from '~/lib/graphql';
|
||||
import { defaultDataIdFromObject } from 'apollo-cache-inmemory';
|
||||
import createDefaultClient from '~/lib/graphql';
|
||||
import createRouter from './router';
|
||||
import AlertDetails from './components/alert_details.vue';
|
||||
import sidebarStatusQuery from './graphql/queries/sidebar_status.query.graphql';
|
||||
|
||||
|
@ -10,6 +11,7 @@ Vue.use(VueApollo);
|
|||
export default selector => {
|
||||
const domEl = document.querySelector(selector);
|
||||
const { alertId, projectPath, projectIssuesPath, projectId } = domEl.dataset;
|
||||
const router = createRouter();
|
||||
|
||||
const resolvers = {
|
||||
Mutation: {
|
||||
|
@ -54,6 +56,7 @@ export default selector => {
|
|||
components: {
|
||||
AlertDetails,
|
||||
},
|
||||
router,
|
||||
render(createElement) {
|
||||
return createElement('alert-details', {});
|
||||
},
|
||||
|
|
|
@ -11,6 +11,12 @@ fragment AlertDetailItem on AlertManagementAlert {
|
|||
updatedAt
|
||||
endedAt
|
||||
details
|
||||
runbook
|
||||
todos {
|
||||
nodes {
|
||||
id
|
||||
}
|
||||
}
|
||||
notes {
|
||||
nodes {
|
||||
...AlertNote
|
||||
|
|
|
@ -1,11 +0,0 @@
|
|||
mutation($projectPath: ID!, $iid: String!) {
|
||||
alertTodoCreate(input: { iid: $iid, projectPath: $projectPath }) {
|
||||
errors
|
||||
alert {
|
||||
iid
|
||||
}
|
||||
todo {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,10 @@
|
|||
#import "../fragments/detail_item.fragment.graphql"
|
||||
|
||||
mutation alertTodoCreate($projectPath: ID!, $iid: String!) {
|
||||
alertTodoCreate(input: { iid: $iid, projectPath: $projectPath }) {
|
||||
errors
|
||||
alert {
|
||||
...AlertDetailItem
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,8 @@
|
|||
mutation todoMarkDone($id: ID!) {
|
||||
todoMarkDone(input: { id: $id }) {
|
||||
errors
|
||||
todo {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,3 @@
|
|||
query alertsHelpUrl {
|
||||
alertsHelpUrl @client
|
||||
}
|
|
@ -1,7 +1,7 @@
|
|||
import Vue from 'vue';
|
||||
import VueApollo from 'vue-apollo';
|
||||
import createDefaultClient from '~/lib/graphql';
|
||||
import { defaultDataIdFromObject } from 'apollo-cache-inmemory';
|
||||
import createDefaultClient from '~/lib/graphql';
|
||||
import { parseBoolean } from '~/lib/utils/common_utils';
|
||||
import AlertManagementList from './components/alert_management_list_wrapper.vue';
|
||||
|
||||
|
@ -16,6 +16,7 @@ export default () => {
|
|||
enableAlertManagementPath,
|
||||
emptyAlertSvgPath,
|
||||
populatingAlertsHelpUrl,
|
||||
alertsHelpUrl,
|
||||
opsgenieMvcTargetUrl,
|
||||
} = domEl.dataset;
|
||||
let { alertManagementEnabled, userCanEnableAlertManagement, opsgenieMvcEnabled } = domEl.dataset;
|
||||
|
@ -41,6 +42,12 @@ export default () => {
|
|||
),
|
||||
});
|
||||
|
||||
apolloProvider.clients.defaultClient.cache.writeData({
|
||||
data: {
|
||||
alertsHelpUrl,
|
||||
},
|
||||
});
|
||||
|
||||
return new Vue({
|
||||
el: selector,
|
||||
apolloProvider,
|
||||
|
|
13
app/assets/javascripts/alert_management/router.js
Normal file
13
app/assets/javascripts/alert_management/router.js
Normal file
|
@ -0,0 +1,13 @@
|
|||
import Vue from 'vue';
|
||||
import VueRouter from 'vue-router';
|
||||
import { joinPaths } from '~/lib/utils/url_utility';
|
||||
|
||||
Vue.use(VueRouter);
|
||||
|
||||
export default function createRouter(base) {
|
||||
return new VueRouter({
|
||||
mode: 'hash',
|
||||
base: joinPaths(gon.relative_url_root || '', base),
|
||||
routes: [{ path: '/:tabId', name: 'tab' }],
|
||||
});
|
||||
}
|
|
@ -12,7 +12,7 @@ import ClipboardButton from '~/vue_shared/components/clipboard_button.vue';
|
|||
import ToggleButton from '~/vue_shared/components/toggle_button.vue';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import { s__, __ } from '~/locale';
|
||||
import createFlash from '~/flash';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
|
||||
export default {
|
||||
i18n: {
|
||||
|
@ -180,9 +180,11 @@ export default {
|
|||
/>
|
||||
</span>
|
||||
</div>
|
||||
<gl-button v-gl-modal.authKeyModal class="mt-2" :disabled="isDisabled">{{
|
||||
<span class="gl-display-flex gl-justify-content-end">
|
||||
<gl-button v-gl-modal.authKeyModal class="gl-mt-2" :disabled="isDisabled">{{
|
||||
$options.RESET_KEY
|
||||
}}</gl-button>
|
||||
</span>
|
||||
<gl-modal
|
||||
modal-id="authKeyModal"
|
||||
:title="$options.RESET_KEY"
|
||||
|
|
|
@ -51,52 +51,26 @@ export default {
|
|||
'gl-modal': GlModalDirective,
|
||||
},
|
||||
mixins: [glFeatureFlagsMixin()],
|
||||
props: {
|
||||
prometheus: {
|
||||
type: Object,
|
||||
required: true,
|
||||
validator: ({ activated }) => {
|
||||
return activated !== undefined;
|
||||
},
|
||||
},
|
||||
generic: {
|
||||
type: Object,
|
||||
required: true,
|
||||
validator: ({ formPath }) => {
|
||||
return formPath !== undefined;
|
||||
},
|
||||
},
|
||||
opsgenie: {
|
||||
type: Object,
|
||||
required: true,
|
||||
},
|
||||
},
|
||||
inject: ['prometheus', 'generic', 'opsgenie'],
|
||||
data() {
|
||||
return {
|
||||
activated: {
|
||||
generic: this.generic.activated,
|
||||
prometheus: this.prometheus.activated,
|
||||
opsgenie: this.opsgenie?.activated,
|
||||
},
|
||||
loading: false,
|
||||
authorizationKey: {
|
||||
generic: this.generic.initialAuthorizationKey,
|
||||
prometheus: this.prometheus.prometheusAuthorizationKey,
|
||||
},
|
||||
selectedEndpoint: serviceOptions[0].value,
|
||||
options: serviceOptions,
|
||||
targetUrl: null,
|
||||
active: false,
|
||||
authKey: '',
|
||||
targetUrl: '',
|
||||
feedback: {
|
||||
variant: 'danger',
|
||||
feedbackMessage: null,
|
||||
feedbackMessage: '',
|
||||
isFeedbackDismissed: false,
|
||||
},
|
||||
serverError: null,
|
||||
testAlert: {
|
||||
json: null,
|
||||
error: null,
|
||||
},
|
||||
canSaveForm: false,
|
||||
serverError: null,
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
|
@ -123,24 +97,24 @@ export default {
|
|||
case 'generic': {
|
||||
return {
|
||||
url: this.generic.url,
|
||||
authKey: this.authorizationKey.generic,
|
||||
active: this.activated.generic,
|
||||
resetKey: this.resetGenericKey.bind(this),
|
||||
authKey: this.generic.authorizationKey,
|
||||
activated: this.generic.activated,
|
||||
resetKey: this.resetKey.bind(this),
|
||||
};
|
||||
}
|
||||
case 'prometheus': {
|
||||
return {
|
||||
url: this.prometheus.prometheusUrl,
|
||||
authKey: this.authorizationKey.prometheus,
|
||||
active: this.activated.prometheus,
|
||||
resetKey: this.resetPrometheusKey.bind(this),
|
||||
authKey: this.prometheus.authorizationKey,
|
||||
activated: this.prometheus.activated,
|
||||
resetKey: this.resetKey.bind(this, 'prometheus'),
|
||||
targetUrl: this.prometheus.prometheusApiUrl,
|
||||
};
|
||||
}
|
||||
case 'opsgenie': {
|
||||
return {
|
||||
targetUrl: this.opsgenie.opsgenieMvcTargetUrl,
|
||||
active: this.activated.opsgenie,
|
||||
activated: this.opsgenie.activated,
|
||||
};
|
||||
}
|
||||
default: {
|
||||
|
@ -164,7 +138,7 @@ export default {
|
|||
return this.testAlert.error === null;
|
||||
},
|
||||
canTestAlert() {
|
||||
return this.selectedService.active && this.testAlert.json !== null;
|
||||
return this.active && this.testAlert.json !== null;
|
||||
},
|
||||
canSaveConfig() {
|
||||
return !this.loading && this.canSaveForm;
|
||||
|
@ -187,19 +161,21 @@ export default {
|
|||
},
|
||||
mounted() {
|
||||
if (
|
||||
this.activated.prometheus ||
|
||||
this.activated.generic ||
|
||||
this.prometheus.activated ||
|
||||
this.generic.activated ||
|
||||
!this.opsgenie.opsgenieMvcIsAvailable
|
||||
) {
|
||||
this.removeOpsGenieOption();
|
||||
} else if (this.activated.opsgenie) {
|
||||
} else if (this.opsgenie.activated) {
|
||||
this.setOpsgenieAsDefault();
|
||||
}
|
||||
this.active = this.selectedService.activated;
|
||||
this.authKey = this.selectedService.authKey ?? '';
|
||||
},
|
||||
methods: {
|
||||
createUserErrorMessage(errors) {
|
||||
createUserErrorMessage(errors = { error: [''] }) {
|
||||
// eslint-disable-next-line prefer-destructuring
|
||||
this.serverError = Object.values(errors)[0][0];
|
||||
this.serverError = errors.error[0];
|
||||
},
|
||||
setOpsgenieAsDefault() {
|
||||
this.options = this.options.map(el => {
|
||||
|
@ -224,41 +200,38 @@ export default {
|
|||
resetFormValues() {
|
||||
this.testAlert.json = null;
|
||||
this.targetUrl = this.selectedService.targetUrl;
|
||||
this.active = this.selectedService.activated;
|
||||
},
|
||||
dismissFeedback() {
|
||||
this.serverError = null;
|
||||
this.feedback = { ...this.feedback, feedbackMessage: null };
|
||||
this.isFeedbackDismissed = false;
|
||||
},
|
||||
resetGenericKey() {
|
||||
return service
|
||||
.updateGenericKey({ endpoint: this.generic.formPath, params: { service: { token: '' } } })
|
||||
resetKey(key) {
|
||||
const fn = key === 'prometheus' ? this.resetPrometheusKey() : this.resetGenericKey();
|
||||
|
||||
return fn
|
||||
.then(({ data: { token } }) => {
|
||||
this.authorizationKey.generic = token;
|
||||
this.authKey = token;
|
||||
this.setFeedback({ feedbackMessage: this.$options.i18n.authKeyRest, variant: 'success' });
|
||||
})
|
||||
.catch(() => {
|
||||
this.setFeedback({ feedbackMessage: this.$options.i18n.errorKeyMsg, variant: 'danger' });
|
||||
});
|
||||
},
|
||||
resetGenericKey() {
|
||||
this.dismissFeedback();
|
||||
return service.updateGenericKey({
|
||||
endpoint: this.generic.formPath,
|
||||
params: { service: { token: '' } },
|
||||
});
|
||||
},
|
||||
resetPrometheusKey() {
|
||||
return service
|
||||
.updatePrometheusKey({ endpoint: this.prometheus.prometheusResetKeyPath })
|
||||
.then(({ data: { token } }) => {
|
||||
this.authorizationKey.prometheus = token;
|
||||
this.setFeedback({ feedbackMessage: this.$options.i18n.authKeyRest, variant: 'success' });
|
||||
})
|
||||
.catch(() => {
|
||||
this.setFeedback({ feedbackMessage: this.$options.i18n.errorKeyMsg, variant: 'danger' });
|
||||
});
|
||||
return service.updatePrometheusKey({ endpoint: this.prometheus.prometheusResetKeyPath });
|
||||
},
|
||||
toggleService(value) {
|
||||
this.canSaveForm = true;
|
||||
if (this.isPrometheus) {
|
||||
this.activated.prometheus = value;
|
||||
} else {
|
||||
this.activated[this.selectedEndpoint] = value;
|
||||
}
|
||||
this.active = value;
|
||||
},
|
||||
toggle(value) {
|
||||
return this.isPrometheus ? this.togglePrometheusActive(value) : this.toggleActivated(value);
|
||||
|
@ -273,7 +246,7 @@ export default {
|
|||
: { service: { active: value } },
|
||||
})
|
||||
.then(() => {
|
||||
this.activated[this.selectedEndpoint] = value;
|
||||
this.active = value;
|
||||
this.toggleSuccess(value);
|
||||
|
||||
if (!this.isOpsgenie && value) {
|
||||
|
@ -316,7 +289,7 @@ export default {
|
|||
},
|
||||
})
|
||||
.then(() => {
|
||||
this.activated.prometheus = value;
|
||||
this.active = value;
|
||||
this.toggleSuccess(value);
|
||||
this.removeOpsGenieOption();
|
||||
})
|
||||
|
@ -358,6 +331,7 @@ export default {
|
|||
},
|
||||
validateTestAlert() {
|
||||
this.loading = true;
|
||||
this.dismissFeedback();
|
||||
this.validateJson();
|
||||
return service
|
||||
.updateTestAlert({
|
||||
|
@ -382,7 +356,8 @@ export default {
|
|||
});
|
||||
},
|
||||
onSubmit() {
|
||||
this.toggle(this.selectedService.active);
|
||||
this.dismissFeedback();
|
||||
this.toggle(this.active);
|
||||
},
|
||||
onReset() {
|
||||
this.testAlert.json = null;
|
||||
|
@ -391,7 +366,7 @@ export default {
|
|||
|
||||
if (this.canSaveForm) {
|
||||
this.canSaveForm = false;
|
||||
this.activated[this.selectedEndpoint] = this[this.selectedEndpoint].activated;
|
||||
this.active = this.selectedService.activated;
|
||||
}
|
||||
},
|
||||
},
|
||||
|
@ -409,7 +384,7 @@ export default {
|
|||
variant="danger"
|
||||
category="primary"
|
||||
class="gl-display-block gl-mt-3"
|
||||
@click="toggle(selectedService.active)"
|
||||
@click="toggle(active)"
|
||||
>
|
||||
{{ __('Save anyway') }}
|
||||
</gl-button>
|
||||
|
@ -435,7 +410,7 @@ export default {
|
|||
data-testid="alert-settings-select"
|
||||
@change="resetFormValues"
|
||||
/>
|
||||
<span class="gl-text-gray-400">
|
||||
<span class="gl-text-gray-200">
|
||||
<gl-sprintf :message="$options.i18n.integrationsInfo">
|
||||
<template #link="{ content }">
|
||||
<gl-link
|
||||
|
@ -457,7 +432,7 @@ export default {
|
|||
id="activated"
|
||||
:disabled-input="loading"
|
||||
:is-loading="loading"
|
||||
:value="selectedService.active"
|
||||
:value="active"
|
||||
@change="toggleService"
|
||||
/>
|
||||
</gl-form-group>
|
||||
|
@ -472,9 +447,9 @@ export default {
|
|||
v-model="targetUrl"
|
||||
type="url"
|
||||
:placeholder="baseUrlPlaceholder"
|
||||
:disabled="!selectedService.active"
|
||||
:disabled="!active"
|
||||
/>
|
||||
<span class="gl-text-gray-400">
|
||||
<span class="gl-text-gray-200">
|
||||
{{ $options.i18n.apiBaseUrlHelpText }}
|
||||
</span>
|
||||
</gl-form-group>
|
||||
|
@ -489,7 +464,7 @@ export default {
|
|||
/>
|
||||
</template>
|
||||
</gl-form-input-group>
|
||||
<span class="gl-text-gray-400">
|
||||
<span class="gl-text-gray-200">
|
||||
{{ prometheusInfo }}
|
||||
</span>
|
||||
</gl-form-group>
|
||||
|
@ -498,21 +473,16 @@ export default {
|
|||
label-for="authorization-key"
|
||||
label-class="label-bold"
|
||||
>
|
||||
<gl-form-input-group
|
||||
id="authorization-key"
|
||||
class="gl-mb-2"
|
||||
readonly
|
||||
:value="selectedService.authKey"
|
||||
>
|
||||
<gl-form-input-group id="authorization-key" class="gl-mb-2" readonly :value="authKey">
|
||||
<template #append>
|
||||
<clipboard-button
|
||||
:text="selectedService.authKey || ''"
|
||||
:text="authKey"
|
||||
:title="$options.i18n.copyToClipboard"
|
||||
class="gl-m-0!"
|
||||
/>
|
||||
</template>
|
||||
</gl-form-input-group>
|
||||
<gl-button v-gl-modal.authKeyModal :disabled="!selectedService.active" class="gl-mt-3">{{
|
||||
<gl-button v-gl-modal.authKeyModal :disabled="!active" class="gl-mt-3">{{
|
||||
$options.i18n.resetKey
|
||||
}}</gl-button>
|
||||
<gl-modal
|
||||
|
@ -534,18 +504,23 @@ export default {
|
|||
<gl-form-textarea
|
||||
id="alert-json"
|
||||
v-model.trim="testAlert.json"
|
||||
:disabled="!selectedService.active"
|
||||
:disabled="!active"
|
||||
:state="jsonIsValid"
|
||||
:placeholder="$options.i18n.alertJsonPlaceholder"
|
||||
rows="6"
|
||||
max-rows="10"
|
||||
/>
|
||||
</gl-form-group>
|
||||
<div class="gl-display-flex gl-justify-content-end">
|
||||
<gl-button :disabled="!canTestAlert" @click="validateTestAlert">{{
|
||||
$options.i18n.testAlertInfo
|
||||
}}</gl-button>
|
||||
</div>
|
||||
</template>
|
||||
<div class="footer-block row-content-block gl-display-flex gl-justify-content-space-between">
|
||||
<gl-button category="primary" :disabled="!canSaveConfig" @click="onReset">
|
||||
{{ __('Cancel') }}
|
||||
</gl-button>
|
||||
<gl-button
|
||||
variant="success"
|
||||
category="primary"
|
||||
|
@ -554,9 +529,6 @@ export default {
|
|||
>
|
||||
{{ __('Save changes') }}
|
||||
</gl-button>
|
||||
<gl-button variant="default" category="primary" :disabled="!canSaveConfig" @click="onReset">
|
||||
{{ __('Cancel') }}
|
||||
</gl-button>
|
||||
</div>
|
||||
</gl-form>
|
||||
</div>
|
||||
|
|
|
@ -35,7 +35,9 @@ export const i18n = {
|
|||
testAlertSuccess: s__(
|
||||
'AlertSettings|Test alert sent successfully. If you have made other changes, please save them now.',
|
||||
),
|
||||
authKeyRest: s__('AlertSettings|Authorization key has been successfully reset'),
|
||||
authKeyRest: s__(
|
||||
'AlertSettings|Authorization key has been successfully reset. Please save your changes now.',
|
||||
),
|
||||
};
|
||||
|
||||
export const serviceOptions = [
|
||||
|
|
|
@ -31,11 +31,13 @@ export default el => {
|
|||
const opsgenieMvcActivated = parseBoolean(opsgenieMvcEnabled);
|
||||
const opsgenieMvcIsAvailable = parseBoolean(opsgenieMvcAvailable);
|
||||
|
||||
const props = {
|
||||
return new Vue({
|
||||
el,
|
||||
provide: {
|
||||
prometheus: {
|
||||
activated: prometheusIsActivated,
|
||||
prometheusUrl,
|
||||
prometheusAuthorizationKey,
|
||||
authorizationKey: prometheusAuthorizationKey,
|
||||
prometheusFormPath,
|
||||
prometheusResetKeyPath,
|
||||
prometheusApiUrl,
|
||||
|
@ -45,7 +47,7 @@ export default el => {
|
|||
alertsUsageUrl,
|
||||
activated: genericActivated,
|
||||
formPath,
|
||||
initialAuthorizationKey: authorizationKey,
|
||||
authorizationKey,
|
||||
url,
|
||||
},
|
||||
opsgenie: {
|
||||
|
@ -54,14 +56,12 @@ export default el => {
|
|||
opsgenieMvcTargetUrl,
|
||||
opsgenieMvcIsAvailable,
|
||||
},
|
||||
};
|
||||
|
||||
return new Vue({
|
||||
el,
|
||||
},
|
||||
components: {
|
||||
AlertSettingsForm,
|
||||
},
|
||||
render(createElement) {
|
||||
return createElement(AlertSettingsForm, {
|
||||
props,
|
||||
});
|
||||
return createElement('alert-settings-form');
|
||||
},
|
||||
});
|
||||
};
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
export default {};
|
|
@ -0,0 +1,28 @@
|
|||
import Vue from 'vue';
|
||||
import ActivityChart from './components/activity_chart.vue';
|
||||
|
||||
export default () => {
|
||||
const containers = document.querySelectorAll('.js-project-analytics-chart');
|
||||
|
||||
if (!containers) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return containers.forEach(container => {
|
||||
const { chartData } = container.dataset;
|
||||
const formattedData = JSON.parse(chartData);
|
||||
|
||||
return new Vue({
|
||||
el: container,
|
||||
provide: {
|
||||
formattedData,
|
||||
},
|
||||
components: {
|
||||
ActivityChart,
|
||||
},
|
||||
render(createElement) {
|
||||
return createElement('activity-chart');
|
||||
},
|
||||
});
|
||||
});
|
||||
};
|
|
@ -0,0 +1,42 @@
|
|||
<script>
|
||||
import { GlColumnChart } from '@gitlab/ui/dist/charts';
|
||||
import { s__ } from '~/locale';
|
||||
|
||||
export default {
|
||||
i18n: {
|
||||
noDataMsg: s__(
|
||||
'ProductAnalytics|There is no data for this type of chart currently. Please see the Setup tab if you have not configured the product analytics tool already.',
|
||||
),
|
||||
},
|
||||
components: {
|
||||
GlColumnChart,
|
||||
},
|
||||
inject: {
|
||||
formattedData: {
|
||||
default: {},
|
||||
},
|
||||
},
|
||||
computed: {
|
||||
seriesData() {
|
||||
return {
|
||||
full: this.formattedData.keys.map((val, idx) => [val, this.formattedData.values[idx]]),
|
||||
};
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div class="gl-xs-w-full">
|
||||
<gl-column-chart
|
||||
v-if="formattedData.keys"
|
||||
:data="seriesData"
|
||||
:x-axis-title="__('Value')"
|
||||
:y-axis-title="__('Number of events')"
|
||||
:x-axis-type="'category'"
|
||||
/>
|
||||
<p v-else data-testid="noActivityChartData">
|
||||
{{ $options.i18n.noDataMsg }}
|
||||
</p>
|
||||
</div>
|
||||
</template>
|
|
@ -1,6 +1,6 @@
|
|||
import axios from './lib/utils/axios_utils';
|
||||
import { joinPaths } from './lib/utils/url_utility';
|
||||
import flash from '~/flash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { __ } from '~/locale';
|
||||
|
||||
const DEFAULT_PER_PAGE = 20;
|
||||
|
@ -9,6 +9,7 @@ const Api = {
|
|||
groupsPath: '/api/:version/groups.json',
|
||||
groupPath: '/api/:version/groups/:id',
|
||||
groupMembersPath: '/api/:version/groups/:id/members',
|
||||
groupMilestonesPath: '/api/:version/groups/:id/milestones',
|
||||
subgroupsPath: '/api/:version/groups/:id/subgroups',
|
||||
namespacesPath: '/api/:version/namespaces.json',
|
||||
groupPackagesPath: '/api/:version/groups/:id/packages',
|
||||
|
@ -55,10 +56,14 @@ const Api = {
|
|||
adminStatisticsPath: '/api/:version/application/statistics',
|
||||
pipelineSinglePath: '/api/:version/projects/:id/pipelines/:pipeline_id',
|
||||
pipelinesPath: '/api/:version/projects/:id/pipelines/',
|
||||
createPipelinePath: '/api/:version/projects/:id/pipeline',
|
||||
environmentsPath: '/api/:version/projects/:id/environments',
|
||||
contextCommitsPath:
|
||||
'/api/:version/projects/:id/merge_requests/:merge_request_iid/context_commits',
|
||||
rawFilePath: '/api/:version/projects/:id/repository/files/:path/raw',
|
||||
issuePath: '/api/:version/projects/:id/issues/:issue_iid',
|
||||
tagsPath: '/api/:version/projects/:id/repository/tags',
|
||||
freezePeriodsPath: '/api/:version/projects/:id/freeze_periods',
|
||||
|
||||
group(groupId, callback = () => {}) {
|
||||
const url = Api.buildUrl(Api.groupPath).replace(':id', groupId);
|
||||
|
@ -106,6 +111,17 @@ const Api = {
|
|||
});
|
||||
},
|
||||
|
||||
groupMilestones(id, options) {
|
||||
const url = Api.buildUrl(this.groupMilestonesPath).replace(':id', encodeURIComponent(id));
|
||||
|
||||
return axios.get(url, {
|
||||
params: {
|
||||
per_page: DEFAULT_PER_PAGE,
|
||||
...options,
|
||||
},
|
||||
});
|
||||
},
|
||||
|
||||
// Return groups list. Filtered by query
|
||||
groups(query, options, callback = () => {}) {
|
||||
const url = Api.buildUrl(Api.groupsPath);
|
||||
|
@ -528,6 +544,12 @@ const Api = {
|
|||
return axios.get(url);
|
||||
},
|
||||
|
||||
createRelease(projectPath, release) {
|
||||
const url = Api.buildUrl(this.releasesPath).replace(':id', encodeURIComponent(projectPath));
|
||||
|
||||
return axios.post(url, release);
|
||||
},
|
||||
|
||||
updateRelease(projectPath, tagName, release) {
|
||||
const url = Api.buildUrl(this.releasePath)
|
||||
.replace(':id', encodeURIComponent(projectPath))
|
||||
|
@ -575,11 +597,45 @@ const Api = {
|
|||
});
|
||||
},
|
||||
|
||||
createPipeline(id, data) {
|
||||
const url = Api.buildUrl(this.createPipelinePath).replace(':id', encodeURIComponent(id));
|
||||
|
||||
return axios.post(url, data, {
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
});
|
||||
},
|
||||
|
||||
environments(id) {
|
||||
const url = Api.buildUrl(this.environmentsPath).replace(':id', encodeURIComponent(id));
|
||||
return axios.get(url);
|
||||
},
|
||||
|
||||
createContextCommits(id, mergeRequestIid, data) {
|
||||
const url = Api.buildUrl(this.contextCommitsPath)
|
||||
.replace(':id', encodeURIComponent(id))
|
||||
.replace(':merge_request_iid', mergeRequestIid);
|
||||
|
||||
return axios.post(url, data);
|
||||
},
|
||||
|
||||
allContextCommits(id, mergeRequestIid) {
|
||||
const url = Api.buildUrl(this.contextCommitsPath)
|
||||
.replace(':id', encodeURIComponent(id))
|
||||
.replace(':merge_request_iid', mergeRequestIid);
|
||||
|
||||
return axios.get(url);
|
||||
},
|
||||
|
||||
removeContextCommits(id, mergeRequestIid, data) {
|
||||
const url = Api.buildUrl(this.contextCommitsPath)
|
||||
.replace(':id', id)
|
||||
.replace(':merge_request_iid', mergeRequestIid);
|
||||
|
||||
return axios.delete(url, { data });
|
||||
},
|
||||
|
||||
getRawFile(id, path, params = { ref: 'master' }) {
|
||||
const url = Api.buildUrl(this.rawFilePath)
|
||||
.replace(':id', encodeURIComponent(id))
|
||||
|
@ -616,6 +672,18 @@ const Api = {
|
|||
});
|
||||
},
|
||||
|
||||
freezePeriods(id) {
|
||||
const url = Api.buildUrl(this.freezePeriodsPath).replace(':id', encodeURIComponent(id));
|
||||
|
||||
return axios.get(url);
|
||||
},
|
||||
|
||||
createFreezePeriod(id, freezePeriod = {}) {
|
||||
const url = Api.buildUrl(this.freezePeriodsPath).replace(':id', encodeURIComponent(id));
|
||||
|
||||
return axios.post(url, freezePeriod);
|
||||
},
|
||||
|
||||
buildUrl(url) {
|
||||
return joinPaths(gon.relative_url_root || '', url.replace(':version', gon.api_version));
|
||||
},
|
||||
|
|
|
@ -7,7 +7,7 @@ import Cookies from 'js-cookie';
|
|||
import { __ } from './locale';
|
||||
import { updateTooltipTitle } from './lib/utils/common_utils';
|
||||
import { isInVueNoteablePage } from './lib/utils/dom_utils';
|
||||
import flash from './flash';
|
||||
import { deprecatedCreateFlash as flash } from './flash';
|
||||
import axios from './lib/utils/axios_utils';
|
||||
import * as Emoji from '~/emoji';
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
import { escape, debounce } from 'lodash';
|
||||
import { mapActions, mapState } from 'vuex';
|
||||
import { GlLoadingIcon, GlFormInput, GlFormGroup } from '@gitlab/ui';
|
||||
import createFlash from '~/flash';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
import { s__, sprintf } from '~/locale';
|
||||
import LoadingButton from '~/vue_shared/components/loading_button.vue';
|
||||
import createEmptyBadge from '../empty_badge';
|
||||
|
@ -184,7 +184,7 @@ export default {
|
|||
@input="debouncedPreview"
|
||||
/>
|
||||
<div class="invalid-feedback">{{ s__('Badges|Please fill in a valid URL') }}</div>
|
||||
<span class="form-text text-muted"> {{ badgeLinkUrlExample }} </span>
|
||||
<span class="form-text text-muted">{{ badgeLinkUrlExample }}</span>
|
||||
</div>
|
||||
|
||||
<div class="form-group">
|
||||
|
@ -199,7 +199,7 @@ export default {
|
|||
@input="debouncedPreview"
|
||||
/>
|
||||
<div class="invalid-feedback">{{ s__('Badges|Please fill in a valid URL') }}</div>
|
||||
<span class="form-text text-muted"> {{ badgeImageUrlExample }} </span>
|
||||
<span class="form-text text-muted">{{ badgeImageUrlExample }}</span>
|
||||
</div>
|
||||
|
||||
<div class="form-group">
|
||||
|
@ -210,22 +210,26 @@ export default {
|
|||
:image-url="renderedImageUrl"
|
||||
:link-url="renderedLinkUrl"
|
||||
/>
|
||||
<p v-show="isRendering"><gl-loading-icon :inline="true" /></p>
|
||||
<p v-show="isRendering">
|
||||
<gl-loading-icon :inline="true" />
|
||||
</p>
|
||||
<p v-show="!renderedBadge && !isRendering" class="disabled-content">
|
||||
{{ s__('Badges|No image to preview') }}
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div v-if="isEditing" class="row-content-block">
|
||||
<div v-if="isEditing" class="row-content-block gl-display-flex gl-justify-content-end">
|
||||
<button class="btn btn-cancel gl-mr-4" type="button" @click="onCancel">
|
||||
{{ __('Cancel') }}
|
||||
</button>
|
||||
<loading-button
|
||||
:loading="isSaving"
|
||||
:label="s__('Badges|Save changes')"
|
||||
type="submit"
|
||||
container-class="btn btn-success"
|
||||
/>
|
||||
<button class="btn btn-cancel" type="button" @click="onCancel">{{ __('Cancel') }}</button>
|
||||
</div>
|
||||
<div v-else class="form-group">
|
||||
<div v-else class="gl-display-flex gl-justify-content-end form-group">
|
||||
<loading-button
|
||||
:loading="isSaving"
|
||||
:label="s__('Badges|Add badge')"
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
<script>
|
||||
import { mapState, mapActions } from 'vuex';
|
||||
import createFlash from '~/flash';
|
||||
import { GlSprintf } from '@gitlab/ui';
|
||||
import { deprecatedCreateFlash as createFlash } from '~/flash';
|
||||
import { s__ } from '~/locale';
|
||||
import DeprecatedModal2 from '~/vue_shared/components/deprecated_modal_2.vue';
|
||||
import Badge from './badge.vue';
|
||||
|
@ -14,14 +15,15 @@ export default {
|
|||
BadgeForm,
|
||||
BadgeList,
|
||||
GlModal: DeprecatedModal2,
|
||||
GlSprintf,
|
||||
},
|
||||
i18n: {
|
||||
deleteModalText: s__(
|
||||
'Badges|You are going to delete this badge. Deleted badges %{strongStart}cannot%{strongEnd} be restored.',
|
||||
),
|
||||
},
|
||||
computed: {
|
||||
...mapState(['badgeInModal', 'isEditing']),
|
||||
deleteModalText() {
|
||||
return s__(
|
||||
'Badges|You are going to delete this badge. Deleted badges <strong>cannot</strong> be restored.',
|
||||
);
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
...mapActions(['deleteBadge']),
|
||||
|
@ -54,7 +56,13 @@ export default {
|
|||
:link-url="badgeInModal ? badgeInModal.renderedLinkUrl : ''"
|
||||
/>
|
||||
</div>
|
||||
<p v-html="deleteModalText"></p>
|
||||
<p>
|
||||
<gl-sprintf :message="$options.i18n.deleteModalText">
|
||||
<template #strong="{ content }">
|
||||
<strong>{{ content }}</strong>
|
||||
</template>
|
||||
</gl-sprintf>
|
||||
</p>
|
||||
</gl-modal>
|
||||
|
||||
<badge-form v-show="isEditing" :is-editing="true" />
|
||||
|
|
|
@ -1,15 +1,17 @@
|
|||
<script>
|
||||
import { mapActions, mapGetters, mapState } from 'vuex';
|
||||
import { GlButton } from '@gitlab/ui';
|
||||
import NoteableNote from '~/notes/components/noteable_note.vue';
|
||||
import LoadingButton from '~/vue_shared/components/loading_button.vue';
|
||||
import PublishButton from './publish_button.vue';
|
||||
import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
NoteableNote,
|
||||
PublishButton,
|
||||
LoadingButton,
|
||||
GlButton,
|
||||
},
|
||||
mixins: [glFeatureFlagsMixin()],
|
||||
props: {
|
||||
draft: {
|
||||
type: Object,
|
||||
|
@ -64,14 +66,27 @@ export default {
|
|||
handleNotEditing() {
|
||||
this.isEditingDraft = false;
|
||||
},
|
||||
handleMouseEnter(draft) {
|
||||
if (this.glFeatures.multilineComments && draft.position) {
|
||||
this.setSelectedCommentPositionHover(draft.position.line_range);
|
||||
}
|
||||
},
|
||||
handleMouseLeave(draft) {
|
||||
// Even though position isn't used here we still don't want to unecessarily call a mutation
|
||||
// The lack of position tells us that highlighting is irrelevant in this context
|
||||
if (this.glFeatures.multilineComments && draft.position) {
|
||||
this.setSelectedCommentPositionHover();
|
||||
}
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
<template>
|
||||
<article
|
||||
role="article"
|
||||
class="draft-note-component note-wrapper"
|
||||
@mouseenter="setSelectedCommentPositionHover(draft.position.line_range)"
|
||||
@mouseleave="setSelectedCommentPositionHover()"
|
||||
@mouseenter="handleMouseEnter(draft)"
|
||||
@mouseleave="handleMouseLeave(draft)"
|
||||
>
|
||||
<ul class="notes draft-notes">
|
||||
<noteable-note
|
||||
|
@ -100,18 +115,15 @@ export default {
|
|||
></div>
|
||||
|
||||
<p class="draft-note-actions d-flex">
|
||||
<publish-button
|
||||
:show-count="true"
|
||||
:should-publish="false"
|
||||
class="btn btn-success btn-inverted gl-mr-3"
|
||||
/>
|
||||
<loading-button
|
||||
<publish-button :show-count="true" :should-publish="false" category="secondary" />
|
||||
<gl-button
|
||||
ref="publishNowButton"
|
||||
:loading="isPublishingDraft(draft.id) || isPublishing"
|
||||
:label="__('Add comment now')"
|
||||
container-class="btn btn-inverted"
|
||||
class="gl-ml-3"
|
||||
@click="publishNow"
|
||||
/>
|
||||
>
|
||||
{{ __('Add comment now') }}
|
||||
</gl-button>
|
||||
</p>
|
||||
</template>
|
||||
</article>
|
||||
|
|
|
@ -1,15 +1,19 @@
|
|||
<script>
|
||||
import { mapGetters } from 'vuex';
|
||||
import { GlBadge } from '@gitlab/ui';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlBadge,
|
||||
},
|
||||
computed: {
|
||||
...mapGetters('batchComments', ['draftsCount']),
|
||||
},
|
||||
};
|
||||
</script>
|
||||
<template>
|
||||
<span class="drafts-count-component">
|
||||
<span class="drafts-count-number">{{ draftsCount }}</span>
|
||||
<gl-badge size="sm" variant="success">
|
||||
{{ draftsCount }}
|
||||
<span class="sr-only"> {{ n__('draft', 'drafts', draftsCount) }} </span>
|
||||
</span>
|
||||
</gl-badge>
|
||||
</template>
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
<script>
|
||||
import { mapActions, mapGetters } from 'vuex';
|
||||
import { GlSprintf } from '@gitlab/ui';
|
||||
import { IMAGE_DIFF_POSITION_TYPE } from '~/diffs/constants';
|
||||
import { sprintf, __ } from '~/locale';
|
||||
import Icon from '~/vue_shared/components/icon.vue';
|
||||
import resolvedStatusMixin from '../mixins/resolved_status';
|
||||
import { GlSprintf } from '@gitlab/ui';
|
||||
import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
|
||||
import {
|
||||
getStartLineNumber,
|
||||
|
|
|
@ -1,12 +1,12 @@
|
|||
<script>
|
||||
import { mapActions, mapState } from 'vuex';
|
||||
import { GlButton } from '@gitlab/ui';
|
||||
import { __ } from '~/locale';
|
||||
import LoadingButton from '~/vue_shared/components/loading_button.vue';
|
||||
import DraftsCount from './drafts_count.vue';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
LoadingButton,
|
||||
GlButton,
|
||||
DraftsCount,
|
||||
},
|
||||
props: {
|
||||
|
@ -20,6 +20,16 @@ export default {
|
|||
required: false,
|
||||
default: __('Finish review'),
|
||||
},
|
||||
category: {
|
||||
type: String,
|
||||
required: false,
|
||||
default: 'primary',
|
||||
},
|
||||
variant: {
|
||||
type: String,
|
||||
required: false,
|
||||
default: 'success',
|
||||
},
|
||||
shouldPublish: {
|
||||
type: Boolean,
|
||||
required: true,
|
||||
|
@ -42,14 +52,14 @@ export default {
|
|||
</script>
|
||||
|
||||
<template>
|
||||
<loading-button
|
||||
<gl-button
|
||||
:loading="isPublishing"
|
||||
container-class="btn btn-success js-publish-draft-button qa-submit-review"
|
||||
class="js-publish-draft-button qa-submit-review"
|
||||
:category="category"
|
||||
:variant="variant"
|
||||
@click="onClick"
|
||||
>
|
||||
<span>
|
||||
{{ label }}
|
||||
<drafts-count v-if="showCount" />
|
||||
</span>
|
||||
</loading-button>
|
||||
</gl-button>
|
||||
</template>
|
||||
|
|
|
@ -1,13 +1,12 @@
|
|||
<script>
|
||||
import { mapActions, mapState, mapGetters } from 'vuex';
|
||||
import { GlModal, GlModalDirective } from '@gitlab/ui';
|
||||
import { GlModal, GlModalDirective, GlButton } from '@gitlab/ui';
|
||||
import { sprintf, s__ } from '~/locale';
|
||||
import LoadingButton from '~/vue_shared/components/loading_button.vue';
|
||||
import PreviewDropdown from './preview_dropdown.vue';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
LoadingButton,
|
||||
GlButton,
|
||||
GlModal,
|
||||
PreviewDropdown,
|
||||
},
|
||||
|
@ -48,12 +47,13 @@ export default {
|
|||
<nav class="review-bar-component">
|
||||
<div class="review-bar-content qa-review-bar">
|
||||
<preview-dropdown />
|
||||
<loading-button
|
||||
<gl-button
|
||||
v-gl-modal="$options.modalId"
|
||||
:loading="isDiscarding"
|
||||
:label="__('Discard review')"
|
||||
class="qa-discard-review float-right"
|
||||
/>
|
||||
>
|
||||
{{ __('Discard review') }}
|
||||
</gl-button>
|
||||
</div>
|
||||
</nav>
|
||||
<gl-modal
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import flash from '~/flash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { __ } from '~/locale';
|
||||
import { scrollToElement } from '~/lib/utils/common_utils';
|
||||
import service from '../../../services/drafts_service';
|
||||
|
@ -146,6 +146,3 @@ export const expandAllDiscussions = ({ dispatch, state }) =>
|
|||
export const toggleResolveDiscussion = ({ commit }, draftId) => {
|
||||
commit(types.TOGGLE_RESOLVE_DISCUSSION, draftId);
|
||||
};
|
||||
|
||||
// prevent babel-plugin-rewire from generating an invalid default during karma tests
|
||||
export default () => {};
|
||||
|
|
|
@ -82,6 +82,3 @@ export const isPublishingDraft = state => draftId =>
|
|||
state.currentlyPublishingDrafts.indexOf(draftId) !== -1;
|
||||
|
||||
export const sortedDrafts = state => [...state.drafts].sort((a, b) => a.id > b.id);
|
||||
|
||||
// prevent babel-plugin-rewire from generating an invalid default during karma tests
|
||||
export default () => {};
|
||||
|
|
|
@ -180,6 +180,10 @@ export class CopyAsGFM {
|
|||
})
|
||||
.catch(() => {});
|
||||
}
|
||||
|
||||
static quoted(markdown) {
|
||||
return `> ${markdown.split('\n').join('\n> ')}`;
|
||||
}
|
||||
}
|
||||
|
||||
// Export CopyAsGFM as a global for rspec to access
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import flash from '~/flash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { s__, sprintf } from '~/locale';
|
||||
|
||||
// Renders math using KaTeX in any element with the
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
import flash from '~/flash';
|
||||
import $ from 'jquery';
|
||||
import { __, sprintf } from '~/locale';
|
||||
import { once } from 'lodash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { __, sprintf } from '~/locale';
|
||||
|
||||
// Renders diagrams and flowcharts from text using Mermaid in any element with the
|
||||
// `js-render-mermaid` class.
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
|
||||
import $ from 'jquery';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import flash from '~/flash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { __ } from '~/locale';
|
||||
|
||||
// MarkdownPreview
|
||||
|
|
|
@ -72,7 +72,7 @@ $(document).on(
|
|||
|
||||
$this.tooltip({
|
||||
container: 'body',
|
||||
html: 'true',
|
||||
html: true,
|
||||
placement: 'top',
|
||||
title,
|
||||
trigger: 'manual',
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import Flash from '../flash';
|
||||
import { deprecatedCreateFlash as Flash } from '../flash';
|
||||
import BalsamiqViewer from './balsamiq/balsamiq_viewer';
|
||||
import { __ } from '~/locale';
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<script>
|
||||
import { __ } from '~/locale';
|
||||
import { GlSprintf, GlLink } from '@gitlab/ui';
|
||||
import { __ } from '~/locale';
|
||||
import { BLOB_RENDER_ERRORS } from './constants';
|
||||
|
||||
export default {
|
||||
|
|
|
@ -1,6 +1,12 @@
|
|||
<script>
|
||||
import { initEditorLite } from '~/blob/utils';
|
||||
import { debounce } from 'lodash';
|
||||
import { initEditorLite } from '~/blob/utils';
|
||||
import {
|
||||
SNIPPET_MARK_BLOBS_CONTENT,
|
||||
SNIPPET_MARK_EDIT_APP_START,
|
||||
SNIPPET_MEASURE_BLOBS_CONTENT,
|
||||
SNIPPET_MEASURE_BLOBS_CONTENT_WITHIN_APP,
|
||||
} from '~/performance_constants';
|
||||
|
||||
export default {
|
||||
props: {
|
||||
|
@ -14,6 +20,13 @@ export default {
|
|||
required: false,
|
||||
default: '',
|
||||
},
|
||||
// This is used to help uniquely create a monaco model
|
||||
// even if two blob's share a file path.
|
||||
fileGlobalId: {
|
||||
type: String,
|
||||
required: false,
|
||||
default: '',
|
||||
},
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
|
@ -30,17 +43,33 @@ export default {
|
|||
el: this.$refs.editor,
|
||||
blobPath: this.fileName,
|
||||
blobContent: this.value,
|
||||
blobGlobalId: this.fileGlobalId,
|
||||
});
|
||||
|
||||
this.editor.onChangeContent(debounce(this.onFileChange.bind(this), 250));
|
||||
|
||||
window.requestAnimationFrame(() => {
|
||||
if (!performance.getEntriesByName(SNIPPET_MARK_BLOBS_CONTENT).length) {
|
||||
performance.mark(SNIPPET_MARK_BLOBS_CONTENT);
|
||||
performance.measure(SNIPPET_MEASURE_BLOBS_CONTENT);
|
||||
performance.measure(SNIPPET_MEASURE_BLOBS_CONTENT_WITHIN_APP, SNIPPET_MARK_EDIT_APP_START);
|
||||
}
|
||||
});
|
||||
},
|
||||
beforeDestroy() {
|
||||
this.editor.dispose();
|
||||
},
|
||||
methods: {
|
||||
triggerFileChange: debounce(function debouncedFileChange() {
|
||||
onFileChange() {
|
||||
this.$emit('input', this.editor.getValue());
|
||||
}, 250),
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
<template>
|
||||
<div class="file-content code">
|
||||
<pre id="editor" ref="editor" data-editor-loading @keyup="triggerFileChange">{{ value }}</pre>
|
||||
<div id="editor" ref="editor" data-editor-loading>
|
||||
<pre class="editor-loading-content">{{ value }}</pre>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -1,9 +1,10 @@
|
|||
<script>
|
||||
import { GlFormInput } from '@gitlab/ui';
|
||||
import { GlFormInput, GlButton } from '@gitlab/ui';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
GlFormInput,
|
||||
GlButton,
|
||||
},
|
||||
inheritAttrs: false,
|
||||
props: {
|
||||
|
@ -11,6 +12,16 @@ export default {
|
|||
type: String,
|
||||
required: true,
|
||||
},
|
||||
canDelete: {
|
||||
type: Boolean,
|
||||
required: false,
|
||||
default: true,
|
||||
},
|
||||
showDelete: {
|
||||
type: Boolean,
|
||||
required: false,
|
||||
default: false,
|
||||
},
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
|
@ -21,8 +32,8 @@ export default {
|
|||
</script>
|
||||
<template>
|
||||
<div class="js-file-title file-title-flex-parent">
|
||||
<div class="gl-display-flex gl-align-items-center gl-w-full">
|
||||
<gl-form-input
|
||||
id="snippet_file_name"
|
||||
v-model="name"
|
||||
:placeholder="
|
||||
s__('Snippets|Give your file a name to add code highlighting, e.g. example.rb for Ruby')
|
||||
|
@ -33,5 +44,15 @@ export default {
|
|||
v-bind="$attrs"
|
||||
@change="$emit('input', name)"
|
||||
/>
|
||||
<gl-button
|
||||
v-if="showDelete"
|
||||
class="gl-ml-4"
|
||||
variant="danger"
|
||||
category="secondary"
|
||||
:disabled="!canDelete"
|
||||
@click="$emit('delete')"
|
||||
>{{ s__('Snippets|Delete file') }}</gl-button
|
||||
>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
|
|
@ -71,7 +71,7 @@ export default {
|
|||
</template>
|
||||
</blob-filepath>
|
||||
|
||||
<div class="file-actions d-none d-sm-flex">
|
||||
<div class="gl-display-none gl-display-sm-flex">
|
||||
<viewer-switcher v-if="showViewerSwitcher" v-model="viewer" />
|
||||
|
||||
<slot name="actions"></slot>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<script>
|
||||
import { GlDeprecatedButton, GlButtonGroup, GlIcon, GlTooltipDirective } from '@gitlab/ui';
|
||||
import { GlButton, GlButtonGroup, GlTooltipDirective } from '@gitlab/ui';
|
||||
import {
|
||||
BTN_COPY_CONTENTS_TITLE,
|
||||
BTN_DOWNLOAD_TITLE,
|
||||
|
@ -10,9 +10,8 @@ import {
|
|||
|
||||
export default {
|
||||
components: {
|
||||
GlIcon,
|
||||
GlButtonGroup,
|
||||
GlDeprecatedButton,
|
||||
GlButton,
|
||||
},
|
||||
directives: {
|
||||
GlTooltip: GlTooltipDirective,
|
||||
|
@ -48,7 +47,7 @@ export default {
|
|||
</script>
|
||||
<template>
|
||||
<gl-button-group>
|
||||
<gl-deprecated-button
|
||||
<gl-button
|
||||
v-if="!hasRenderError"
|
||||
v-gl-tooltip.hover
|
||||
:aria-label="$options.BTN_COPY_CONTENTS_TITLE"
|
||||
|
@ -56,26 +55,29 @@ export default {
|
|||
:disabled="copyDisabled"
|
||||
data-clipboard-target="#blob-code-content"
|
||||
data-testid="copyContentsButton"
|
||||
>
|
||||
<gl-icon name="copy-to-clipboard" :size="14" />
|
||||
</gl-deprecated-button>
|
||||
<gl-deprecated-button
|
||||
icon="copy-to-clipboard"
|
||||
category="primary"
|
||||
variant="default"
|
||||
/>
|
||||
<gl-button
|
||||
v-gl-tooltip.hover
|
||||
:aria-label="$options.BTN_RAW_TITLE"
|
||||
:title="$options.BTN_RAW_TITLE"
|
||||
:href="rawPath"
|
||||
target="_blank"
|
||||
>
|
||||
<gl-icon name="doc-code" :size="14" />
|
||||
</gl-deprecated-button>
|
||||
<gl-deprecated-button
|
||||
icon="doc-code"
|
||||
category="primary"
|
||||
variant="default"
|
||||
/>
|
||||
<gl-button
|
||||
v-gl-tooltip.hover
|
||||
:aria-label="$options.BTN_DOWNLOAD_TITLE"
|
||||
:title="$options.BTN_DOWNLOAD_TITLE"
|
||||
:href="downloadUrl"
|
||||
target="_blank"
|
||||
>
|
||||
<gl-icon name="download" :size="14" />
|
||||
</gl-deprecated-button>
|
||||
icon="download"
|
||||
category="primary"
|
||||
variant="default"
|
||||
/>
|
||||
</gl-button-group>
|
||||
</template>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<script>
|
||||
import { GlButton, GlButtonGroup, GlIcon, GlTooltipDirective } from '@gitlab/ui';
|
||||
import { GlButton, GlButtonGroup, GlTooltipDirective } from '@gitlab/ui';
|
||||
import {
|
||||
RICH_BLOB_VIEWER,
|
||||
RICH_BLOB_VIEWER_TITLE,
|
||||
|
@ -9,7 +9,6 @@ import {
|
|||
|
||||
export default {
|
||||
components: {
|
||||
GlIcon,
|
||||
GlButtonGroup,
|
||||
GlButton,
|
||||
},
|
||||
|
@ -52,19 +51,21 @@ export default {
|
|||
:title="$options.SIMPLE_BLOB_VIEWER_TITLE"
|
||||
:selected="isSimpleViewer"
|
||||
:class="{ active: isSimpleViewer }"
|
||||
icon="code"
|
||||
category="primary"
|
||||
variant="default"
|
||||
@click="switchToViewer($options.SIMPLE_BLOB_VIEWER)"
|
||||
>
|
||||
<gl-icon name="code" :size="14" />
|
||||
</gl-button>
|
||||
/>
|
||||
<gl-button
|
||||
v-gl-tooltip.hover
|
||||
:aria-label="$options.RICH_BLOB_VIEWER_TITLE"
|
||||
:title="$options.RICH_BLOB_VIEWER_TITLE"
|
||||
:selected="isRichViewer"
|
||||
:class="{ active: isRichViewer }"
|
||||
icon="document"
|
||||
category="primary"
|
||||
variant="default"
|
||||
@click="switchToViewer($options.RICH_BLOB_VIEWER)"
|
||||
>
|
||||
<gl-icon name="document" :size="14" />
|
||||
</gl-button>
|
||||
/>
|
||||
</gl-button-group>
|
||||
</template>
|
||||
|
|
|
@ -1,12 +1,13 @@
|
|||
import $ from 'jquery';
|
||||
import Api from '~/api';
|
||||
|
||||
import Flash from '../flash';
|
||||
import { deprecatedCreateFlash as Flash } from '../flash';
|
||||
import FileTemplateTypeSelector from './template_selectors/type_selector';
|
||||
import BlobCiYamlSelector from './template_selectors/ci_yaml_selector';
|
||||
import DockerfileSelector from './template_selectors/dockerfile_selector';
|
||||
import GitignoreSelector from './template_selectors/gitignore_selector';
|
||||
import LicenseSelector from './template_selectors/license_selector';
|
||||
import MetricsDashboardSelector from './template_selectors/metrics_dashboard_selector';
|
||||
import toast from '~/vue_shared/plugins/global_toast';
|
||||
import { __ } from '~/locale';
|
||||
import initPopover from '~/blob/suggest_gitlab_ci_yml';
|
||||
|
@ -30,6 +31,7 @@ export default class FileTemplateMediator {
|
|||
this.templateSelectors = [
|
||||
GitignoreSelector,
|
||||
BlobCiYamlSelector,
|
||||
MetricsDashboardSelector,
|
||||
DockerfileSelector,
|
||||
LicenseSelector,
|
||||
].map(TemplateSelectorClass => new TemplateSelectorClass({ mediator: this }));
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<script>
|
||||
import { GlLoadingIcon } from '@gitlab/ui';
|
||||
import axios from '~/lib/utils/axios_utils';
|
||||
import notebookLab from '~/notebook/index.vue';
|
||||
import { GlLoadingIcon } from '@gitlab/ui';
|
||||
|
||||
export default {
|
||||
components: {
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import { SwaggerUIBundle } from 'swagger-ui-dist';
|
||||
import flash from '~/flash';
|
||||
import { deprecatedCreateFlash as flash } from '~/flash';
|
||||
import { __ } from '~/locale';
|
||||
|
||||
export default () => {
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue